You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
146 lines
3.8 KiB
146 lines
3.8 KiB
2 years ago
|
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
|
||
|
volumeProperty SetInterpolationTypeToLinear
|
||
|
|
||
|
vtkVolumeRayCastCompositeFunction f
|
||
|
vtkVolumeRayCastMapper volumeMapper
|
||
|
volumeMapper SetInput $readerOutput
|
||
|
volumeMapper SetVolumeRayCastFunction f
|
||
|
volumeMapper SetSampleDistance 0.3
|
||
|
|
||
|
# 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
|
||
|
|
||
|
# Compute random scalars (colors) for each cell
|
||
|
vtkProgrammableAttributeDataFilter randomColors
|
||
|
randomColors SetInputConnection [sphereSource GetOutputPort]
|
||
|
randomColors SetExecuteMethod colorCells
|
||
|
|
||
|
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
|
||
|
}
|
||
|
|
||
|
vtkPolyDataMapper sphereMapper
|
||
|
sphereMapper SetInput [randomColors GetPolyDataOutput]
|
||
|
|
||
|
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
|
||
|
|