<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=us-ascii"><meta name=Generator content="Microsoft Word 12 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:Wingdings;
        panose-1:5 0 0 0 0 0 0 0 0 0;}
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p.MsoListParagraph, li.MsoListParagraph, div.MsoListParagraph
        {mso-style-priority:34;
        margin-top:0in;
        margin-right:0in;
        margin-bottom:0in;
        margin-left:.5in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri","sans-serif";
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
/* List Definitions */
@list l0
        {mso-list-id:176165576;
        mso-list-type:hybrid;
        mso-list-template-ids:717011890 1512203220 67698691 67698693 67698689 67698691 67698693 67698689 67698691 67698693;}
@list l0:level1
        {mso-level-number-format:bullet;
        mso-level-text:-;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:"Calibri","sans-serif";
        mso-fareast-font-family:Calibri;}
ol
        {margin-bottom:0in;}
ul
        {margin-bottom:0in;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=EN-US link=blue vlink=purple><div class=WordSection1><p class=MsoNormal>Hi<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>I am trying to figure out why for a specific dataset the volume rendering is not visible UNLESS I am interacting with the window.<o:p></o:p></p><p class=MsoNormal>In other words, the still render is not visible. For other example datasets (head from VTK_DATA), the still render is visible.<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>I am using the vtkVolumeTextureMapper3D (from vtk 5.8.0). The same thing happens on OSX and Win7 installations with different hardware.<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>Additional information:<o:p></o:p></p><p class=MsoListParagraph style='text-indent:-.25in;mso-list:l0 level1 lfo1'><![if !supportLists]><span style='mso-list:Ignore'>-<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span><![endif]>vtkGPUVolumeRayCastMapper works fine for the dataset<o:p></o:p></p><p class=MsoListParagraph style='text-indent:-.25in;mso-list:l0 level1 lfo1'><![if !supportLists]><span style='mso-list:Ignore'>-<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span><![endif]>For whatever reason, if use the vtkSmartVolumeMapper, the still render is visible even if I set the render mode to texture. <o:p></o:p></p><p class=MsoListParagraph style='text-indent:-.25in;mso-list:l0 level1 lfo1'><![if !supportLists]><span style='mso-list:Ignore'>-<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span><![endif]>The image data is 64x64x64, unsigned char, scaled to fit in 0-255.<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>Thanks for any ideas what might be going wrong. Below is the script I am using to visualize the data.<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>Thanks,<o:p></o:p></p><p class=MsoNormal>Bryn<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>reader = vtk.vtkDataSetReader()<o:p></o:p></p><p class=MsoNormal>reader.SetFileName(&quot;C:/Temp/debug_imagedata.vtk&quot;)<o:p></o:p></p><p class=MsoNormal>reader.Update()<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>input = reader.GetStructuredPointsOutput()<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>bounds = [0,0,0,0,0,0]<o:p></o:p></p><p class=MsoNormal>input.GetBounds(bounds)<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>resample = vtk.vtkImageResample()<o:p></o:p></p><p class=MsoNormal>resample.SetInputConnection(reader.GetOutputPort())<o:p></o:p></p><p class=MsoNormal>resample.SetAxisOutputSpacing(0, (bounds[1]-bounds[0])/63.0)<o:p></o:p></p><p class=MsoNormal>resample.SetAxisOutputSpacing(1, (bounds[3]-bounds[2])/63.0)<o:p></o:p></p><p class=MsoNormal>resample.SetAxisOutputSpacing(2, (bounds[5]-bounds[4])/63.0)<o:p></o:p></p><p class=MsoNormal>resample.Update()<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>dims = [0,0,0]<o:p></o:p></p><p class=MsoNormal>resample.GetOutput().GetDimensions(dims)<o:p></o:p></p><p class=MsoNormal>print &quot;Dimensions: &quot;,dims<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>srange = [0,0]<o:p></o:p></p><p class=MsoNormal>resample.GetOutput().GetPointData().GetScalars().GetRange(srange)<o:p></o:p></p><p class=MsoNormal>print &quot;Scalar range: &quot;, srange<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>scale = vtk.vtkImageShiftScale()<o:p></o:p></p><p class=MsoNormal>scale.SetInputConnection(resample.GetOutputPort())<o:p></o:p></p><p class=MsoNormal>scale.SetShift(-srange[0])<o:p></o:p></p><p class=MsoNormal>scale.SetScale(255.0/(srange[1]-srange[0]))<o:p></o:p></p><p class=MsoNormal>scale.ClampOverflowOn()<o:p></o:p></p><p class=MsoNormal>scale.SetOutputScalarTypeToUnsignedChar()<o:p></o:p></p><p class=MsoNormal>scale.Update()<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>volumeMapper = vtk.vtkVolumeTextureMapper3D()<o:p></o:p></p><p class=MsoNormal>volumeMapper.SetInputConnection(scale.GetOutputPort())<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>volumeColor = vtk.vtkColorTransferFunction()<o:p></o:p></p><p class=MsoNormal>volumeColor.RemoveAllPoints()<o:p></o:p></p><p class=MsoNormal>volumeColor.AddRGBPoint(0.00, 0.0,0.0,1.0)<o:p></o:p></p><p class=MsoNormal>volumeColor.AddRGBPoint(100, 1.0,1.0,0.0)<o:p></o:p></p><p class=MsoNormal>volumeColor.AddRGBPoint(255, 1.0,0.0,0.0)<o:p></o:p></p><p class=MsoNormal>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <o:p></o:p></p><p class=MsoNormal>volumeScalarOpacity = vtk.vtkPiecewiseFunction()<o:p></o:p></p><p class=MsoNormal>volumeScalarOpacity.RemoveAllPoints()<o:p></o:p></p><p class=MsoNormal>volumeScalarOpacity.AddPoint(&nbsp; 0, 1.0)<o:p></o:p></p><p class=MsoNormal>volumeScalarOpacity.AddPoint( 50, 1.0)<o:p></o:p></p><p class=MsoNormal>volumeScalarOpacity.AddPoint(150, 1.0)<o:p></o:p></p><p class=MsoNormal>volumeScalarOpacity.AddPoint(200, 1.0)<o:p></o:p></p><p class=MsoNormal>volumeScalarOpacity.AddPoint(255, 1.0)<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>volumeProperty = vtk.vtkVolumeProperty()<o:p></o:p></p><p class=MsoNormal>volumeProperty.SetColor(volumeColor)<o:p></o:p></p><p class=MsoNormal>volumeProperty.SetScalarOpacity(volumeScalarOpacity)<o:p></o:p></p><p class=MsoNormal>volumeProperty.SetInterpolationTypeToLinear()<o:p></o:p></p><p class=MsoNormal>volumeProperty.ShadeOn()<o:p></o:p></p><p class=MsoNormal>volumeProperty.SetAmbient(0.6)<o:p></o:p></p><p class=MsoNormal>volumeProperty.SetDiffuse(0.6)<o:p></o:p></p><p class=MsoNormal>volumeProperty.SetSpecular(0.5)<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>volume = vtk.vtkVolume()<o:p></o:p></p><p class=MsoNormal>volume.SetMapper(volumeMapper)<o:p></o:p></p><p class=MsoNormal>volume.SetProperty(volumeProperty)<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>#-----------------------------------------------------<o:p></o:p></p><p class=MsoNormal># Create the standard renderer, render window and interactor<o:p></o:p></p><p class=MsoNormal><span lang=DE-CH>ren = vtk.vtkRenderer()<o:p></o:p></span></p><p class=MsoNormal><span lang=DE-CH>renWin = vtk.vtkRenderWindow()<o:p></o:p></span></p><p class=MsoNormal><span lang=DE-CH>renWin.AddRenderer(ren)<o:p></o:p></span></p><p class=MsoNormal><span lang=DE-CH>iren = vtk.vtkRenderWindowInteractor()<o:p></o:p></span></p><p class=MsoNormal><span lang=DE-CH>iren.SetRenderWindow(renWin)<o:p></o:p></span></p><p class=MsoNormal><span lang=DE-CH><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><span lang=DE-CH>ren.SetBackground(0.5,0.5,0.5)<o:p></o:p></span></p><p class=MsoNormal>ren.AddVolume(volume)<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>renWin.Render()<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>def CheckAbort(obj, event):<o:p></o:p></p><p class=MsoNormal>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if obj.GetEventPending() != 0:<o:p></o:p></p><p class=MsoNormal>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; obj.SetAbortRender(1)<o:p></o:p></p><p class=MsoNormal>&nbsp; <o:p></o:p></p><p class=MsoNormal>renWin.AddObserver(&quot;AbortCheckEvent&quot;, CheckAbort)<o:p></o:p></p><p class=MsoNormal>iren.Initialize()<o:p></o:p></p><p class=MsoNormal>renWin.Render()<o:p></o:p></p><p class=MsoNormal>iren.Start()<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p></div></body></html>