package require vtk # Simple volume rendering example. vtkImageReader reader reader SetDataByteOrderToLittleEndian reader SetDataExtent 0 63 0 63 1 93 reader SetFilePrefix "$VTK_DATA_ROOT/Data/headsq/quarter" reader SetDataMask 0x7fff reader SetDataSpacing 2 2 1 reader SetDataScalarTypeToUnsignedShort reader Update set readerOutput [reader GetOutput] $readerOutput SetOrigin -63 -63 -46 # Disconnect the output from its reader. First get an extra reference. $readerOutput Register {} $readerOutput SetSource {} # Create transfer functions for opacity and color vtkPiecewiseFunction opacityTransferFunction opacityTransferFunction AddPoint 600 0.0 opacityTransferFunction AddPoint 2000 1.0 vtkColorTransferFunction colorTransferFunction colorTransferFunction ClampingOff colorTransferFunction AddHSVPoint 0.0 0.01 1.0 1.0 colorTransferFunction AddHSVPoint 1000.0 0.50 1.0 1.0 colorTransferFunction AddHSVPoint 2000.0 0.99 1.0 1.0 colorTransferFunction SetColorSpaceToHSV # Create properties, mappers, volume actors, and ray cast function vtkVolumeProperty volumeProperty volumeProperty SetColor colorTransferFunction volumeProperty SetScalarOpacity opacityTransferFunction vtkVolumeTextureMapper2D volumeMapper volumeMapper SetInput $readerOutput volumeMapper SetMaximumStorageSize 10000000 # The data object is now referenced by the connection. $readerOutput UnRegister {} vtkVolume volume volume SetMapper volumeMapper volume SetProperty volumeProperty # Create geometric sphere vtkSphereSource sphereSource sphereSource SetRadius 65 sphereSource SetThetaResolution 20 sphereSource SetPhiResolution 40 proc colorCells {} { vtkMath randomColorGenerator set input [randomColors GetInput] set output [randomColors GetOutput] set numCells [$input GetNumberOfCells] vtkFloatArray colors colors SetNumberOfTuples $numCells for {set i 0} {$i < $numCells} {incr i} { colors SetValue $i [randomColorGenerator Random 0 1] } [$output GetCellData] CopyScalarsOff [$output GetCellData] PassData [$input GetCellData] [$output GetCellData] SetScalars colors colors Delete; #reference counting - it's ok randomColorGenerator Delete } # Compute random scalars (colors) for each cell vtkProgrammableAttributeDataFilter randomColors randomColors SetInputConnection [sphereSource GetOutputPort] randomColors SetExecuteMethod colorCells # This does not need a hierarchical mapper, but hierarchical # mapper could use a test that has clipping so we use it here vtkHierarchicalPolyDataMapper sphereMapper sphereMapper SetInputConnection [randomColors GetOutputPort 0] vtkActor sphereActor sphereActor SetMapper sphereMapper # Set up the planes vtkPlane plane1 plane1 SetOrigin 0 0 -10 plane1 SetNormal 0 0 1 vtkPlane plane2 plane2 SetOrigin 0 0 10 plane2 SetNormal 0 0 -1 vtkPlane plane3 plane3 SetOrigin -10 0 0 plane3 SetNormal 1 0 0 vtkPlane plane4 plane4 SetOrigin 10 0 0 plane4 SetNormal -1 0 0 sphereMapper AddClippingPlane plane1 sphereMapper AddClippingPlane plane2 volumeMapper AddClippingPlane plane3 volumeMapper AddClippingPlane plane4 # Okay now the graphics stuff vtkRenderer ren1 vtkRenderWindow renWin renWin AddRenderer ren1 renWin SetSize 256 256 vtkRenderWindowInteractor iren iren SetRenderWindow renWin [ren1 GetCullers] InitTraversal set culler [[ren1 GetCullers] GetNextItem] $culler SetSortingStyleToBackToFront ren1 AddViewProp sphereActor ren1 AddViewProp volume ren1 SetBackground 0.1 0.2 0.4 renWin Render [ren1 GetActiveCamera] Azimuth 45 [ren1 GetActiveCamera] Elevation 15 [ren1 GetActiveCamera] Roll 45 [ren1 GetActiveCamera] Zoom 2.0 wm withdraw . iren Initialize for { set i 0 } { $i < 5 } { incr i } { volume RotateY 17 volume RotateZ 13 sphereActor RotateX 13 sphereActor RotateY 17 renWin Render }