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.
350 lines
9.7 KiB
350 lines
9.7 KiB
2 years ago
|
package require vtk
|
||
|
|
||
|
# Create a gaussian
|
||
|
vtkImageGaussianSource gs
|
||
|
gs SetWholeExtent 0 30 0 30 0 30
|
||
|
gs SetMaximum 255.0
|
||
|
gs SetStandardDeviation 5
|
||
|
gs SetCenter 15 15 15
|
||
|
|
||
|
# threshold to leave a gap that should show up for
|
||
|
# gradient opacity
|
||
|
vtkImageThreshold t
|
||
|
t SetInputConnection [gs GetOutputPort]
|
||
|
t ReplaceInOn
|
||
|
t SetInValue 0
|
||
|
t ThresholdBetween 150 200
|
||
|
|
||
|
# Use a shift scale to convert to unsigned char
|
||
|
vtkImageShiftScale ss
|
||
|
ss SetInputConnection [t GetOutputPort]
|
||
|
ss SetOutputScalarTypeToUnsignedChar
|
||
|
|
||
|
# grid will be used for two component dependent
|
||
|
vtkImageGridSource grid0
|
||
|
grid0 SetDataScalarTypeToUnsignedChar
|
||
|
grid0 SetGridSpacing 10 10 10
|
||
|
grid0 SetLineValue 200
|
||
|
grid0 SetFillValue 10
|
||
|
grid0 SetDataExtent 0 30 0 30 0 30
|
||
|
|
||
|
# use dilation to thicken the grid
|
||
|
vtkImageContinuousDilate3D d
|
||
|
d SetInputConnection [grid0 GetOutputPort]
|
||
|
d SetKernelSize 3 3 3
|
||
|
|
||
|
# Now make a two component dependent
|
||
|
vtkImageAppendComponents iac
|
||
|
iac AddInput [d GetOutput]
|
||
|
iac AddInput [ss GetOutput]
|
||
|
|
||
|
# Some more gaussians for the four component indepent case
|
||
|
vtkImageGaussianSource gs1
|
||
|
gs1 SetWholeExtent 0 30 0 30 0 30
|
||
|
gs1 SetMaximum 255.0
|
||
|
gs1 SetStandardDeviation 4
|
||
|
gs1 SetCenter 5 5 5
|
||
|
|
||
|
vtkImageThreshold t1
|
||
|
t1 SetInputConnection [gs1 GetOutputPort]
|
||
|
t1 ReplaceInOn
|
||
|
t1 SetInValue 0
|
||
|
t1 ThresholdBetween 150 256
|
||
|
|
||
|
vtkImageGaussianSource gs2
|
||
|
gs2 SetWholeExtent 0 30 0 30 0 30
|
||
|
gs2 SetMaximum 255.0
|
||
|
gs2 SetStandardDeviation 4
|
||
|
gs2 SetCenter 12 12 12
|
||
|
|
||
|
vtkImageGaussianSource gs3
|
||
|
gs3 SetWholeExtent 0 30 0 30 0 30
|
||
|
gs3 SetMaximum 255.0
|
||
|
gs3 SetStandardDeviation 4
|
||
|
gs3 SetCenter 19 19 19
|
||
|
|
||
|
vtkImageThreshold t3
|
||
|
t3 SetInputConnection [gs3 GetOutputPort]
|
||
|
t3 ReplaceInOn
|
||
|
t3 SetInValue 0
|
||
|
t3 ThresholdBetween 150 256
|
||
|
|
||
|
vtkImageGaussianSource gs4
|
||
|
gs4 SetWholeExtent 0 30 0 30 0 30
|
||
|
gs4 SetMaximum 255.0
|
||
|
gs4 SetStandardDeviation 4
|
||
|
gs4 SetCenter 26 26 26
|
||
|
|
||
|
# we need a few append filters ...
|
||
|
vtkImageAppendComponents iac1
|
||
|
iac1 AddInput [t1 GetOutput]
|
||
|
iac1 AddInput [gs2 GetOutput]
|
||
|
|
||
|
vtkImageAppendComponents iac2
|
||
|
iac2 AddInput [iac1 GetOutput]
|
||
|
iac2 AddInput [t3 GetOutput]
|
||
|
|
||
|
vtkImageAppendComponents iac3
|
||
|
iac3 AddInput [iac2 GetOutput]
|
||
|
iac3 AddInput [gs4 GetOutput]
|
||
|
|
||
|
# create the four component dependend -
|
||
|
# use lines in x, y, z for colors
|
||
|
vtkImageGridSource gridR
|
||
|
gridR SetDataScalarTypeToUnsignedChar
|
||
|
gridR SetGridSpacing 10 100 100
|
||
|
gridR SetLineValue 250
|
||
|
gridR SetFillValue 100
|
||
|
gridR SetDataExtent 0 30 0 30 0 30
|
||
|
|
||
|
vtkImageContinuousDilate3D dR
|
||
|
dR SetInputConnection [gridR GetOutputPort]
|
||
|
dR SetKernelSize 2 2 2
|
||
|
|
||
|
vtkImageGridSource gridG
|
||
|
gridG SetDataScalarTypeToUnsignedChar
|
||
|
gridG SetGridSpacing 100 10 100
|
||
|
gridG SetLineValue 250
|
||
|
gridG SetFillValue 100
|
||
|
gridG SetDataExtent 0 30 0 30 0 30
|
||
|
|
||
|
vtkImageContinuousDilate3D dG
|
||
|
dG SetInputConnection [gridG GetOutputPort]
|
||
|
dG SetKernelSize 2 2 2
|
||
|
|
||
|
vtkImageGridSource gridB
|
||
|
gridB SetDataScalarTypeToUnsignedChar
|
||
|
gridB SetGridSpacing 100 100 10
|
||
|
gridB SetLineValue 0
|
||
|
gridB SetFillValue 250
|
||
|
gridB SetDataExtent 0 30 0 30 0 30
|
||
|
|
||
|
vtkImageContinuousDilate3D dB
|
||
|
dB SetInputConnection [gridB GetOutputPort]
|
||
|
dB SetKernelSize 2 2 2
|
||
|
|
||
|
# need some appending
|
||
|
vtkImageAppendComponents iacRG
|
||
|
iacRG AddInput [dR GetOutput]
|
||
|
iacRG AddInput [dG GetOutput]
|
||
|
|
||
|
vtkImageAppendComponents iacRGB
|
||
|
iacRGB AddInput [iacRG GetOutput]
|
||
|
iacRGB AddInput [dB GetOutput]
|
||
|
|
||
|
vtkImageAppendComponents iacRGBA
|
||
|
iacRGBA AddInput [iacRGB GetOutput]
|
||
|
iacRGBA AddInput [ss GetOutput]
|
||
|
|
||
|
# We need a bunch of opacity functions
|
||
|
|
||
|
# this one is a simple ramp to .2
|
||
|
vtkPiecewiseFunction rampPoint2
|
||
|
rampPoint2 AddPoint 0 0.0
|
||
|
rampPoint2 AddPoint 255 0.2
|
||
|
|
||
|
# this one is a simple ramp to 1
|
||
|
vtkPiecewiseFunction ramp1
|
||
|
ramp1 AddPoint 0 0.0
|
||
|
ramp1 AddPoint 255 1.0
|
||
|
|
||
|
# this one shows a sharp surface
|
||
|
vtkPiecewiseFunction surface
|
||
|
surface AddPoint 0 0.0
|
||
|
surface AddPoint 10 0.0
|
||
|
surface AddPoint 50 1.0
|
||
|
surface AddPoint 255 1.0
|
||
|
|
||
|
|
||
|
# this one is constant 1
|
||
|
vtkPiecewiseFunction constant1
|
||
|
constant1 AddPoint 0 1.0
|
||
|
constant1 AddPoint 255 1.0
|
||
|
|
||
|
# this one is used for gradient opacity
|
||
|
vtkPiecewiseFunction gop
|
||
|
gop AddPoint 0 0.0
|
||
|
gop AddPoint 20 0.0
|
||
|
gop AddPoint 60 1.0
|
||
|
gop AddPoint 255 1.0
|
||
|
|
||
|
|
||
|
# We need a bunch of color functions
|
||
|
|
||
|
# This one is a simple rainbow
|
||
|
vtkColorTransferFunction rainbow
|
||
|
rainbow SetColorSpaceToHSV
|
||
|
rainbow HSVWrapOff
|
||
|
rainbow AddHSVPoint 0 0.1 1.0 1.0
|
||
|
rainbow AddHSVPoint 255 0.9 1.0 1.0
|
||
|
|
||
|
# this is constant red
|
||
|
vtkColorTransferFunction red
|
||
|
red AddRGBPoint 0 1 0 0
|
||
|
red AddRGBPoint 255 1 0 0
|
||
|
|
||
|
# this is constant green
|
||
|
vtkColorTransferFunction green
|
||
|
green AddRGBPoint 0 0 1 0
|
||
|
green AddRGBPoint 255 0 1 0
|
||
|
|
||
|
# this is constant blue
|
||
|
vtkColorTransferFunction blue
|
||
|
blue AddRGBPoint 0 0 0 1
|
||
|
blue AddRGBPoint 255 0 0 1
|
||
|
|
||
|
# this is constant yellow
|
||
|
vtkColorTransferFunction yellow
|
||
|
yellow AddRGBPoint 0 1 1 0
|
||
|
yellow AddRGBPoint 255 1 1 0
|
||
|
|
||
|
|
||
|
vtkRenderer ren1
|
||
|
vtkRenderWindow renWin
|
||
|
renWin AddRenderer ren1
|
||
|
renWin SetSize 500 500
|
||
|
vtkRenderWindowInteractor iren
|
||
|
iren SetRenderWindow renWin
|
||
|
|
||
|
[ren1 GetCullers] InitTraversal
|
||
|
set culler [[ren1 GetCullers] GetNextItem]
|
||
|
$culler SetSortingStyleToBackToFront
|
||
|
|
||
|
# We need 25 mapper / actor pairs which we will render
|
||
|
# in a grid. Going down we will vary the input data
|
||
|
# with the top row unsigned char, then float, then
|
||
|
# two dependent components, then four dependent components
|
||
|
# then four independent components. Going across we
|
||
|
# will vary the rendering method with MIP, Composite,
|
||
|
# Composite Shade, Composite GO, and Composite GO Shade.
|
||
|
|
||
|
for { set j 0 } { $j < 5 } { incr j } {
|
||
|
for { set i 0 } { $i < 5 } { incr i } {
|
||
|
vtkVolumeProperty volumeProperty${i}${j}
|
||
|
vtkFixedPointVolumeRayCastMapper volumeMapper${i}${j}
|
||
|
volumeMapper${i}${j} SetSampleDistance 0.25
|
||
|
|
||
|
vtkVolume volume${i}${j}
|
||
|
volume${i}${j} SetMapper volumeMapper${i}${j}
|
||
|
volume${i}${j} SetProperty volumeProperty${i}${j}
|
||
|
|
||
|
volume${i}${j} AddPosition [expr $i*30] [expr $j*30] 0
|
||
|
|
||
|
ren1 AddVolume volume${i}${j}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
for { set i 0 } { $i < 5 } { incr i } {
|
||
|
volumeMapper0${i} SetInputConnection [t GetOutputPort]
|
||
|
volumeMapper1${i} SetInputConnection [ss GetOutputPort]
|
||
|
volumeMapper2${i} SetInputConnection [iac GetOutputPort]
|
||
|
volumeMapper3${i} SetInputConnection [iac3 GetOutputPort]
|
||
|
volumeMapper4${i} SetInputConnection [iacRGBA GetOutputPort]
|
||
|
|
||
|
volumeMapper${i}0 SetBlendModeToMaximumIntensity
|
||
|
volumeMapper${i}1 SetBlendModeToComposite
|
||
|
volumeMapper${i}2 SetBlendModeToComposite
|
||
|
volumeMapper${i}3 SetBlendModeToComposite
|
||
|
volumeMapper${i}4 SetBlendModeToComposite
|
||
|
|
||
|
volumeProperty0${i} IndependentComponentsOn
|
||
|
volumeProperty1${i} IndependentComponentsOn
|
||
|
volumeProperty2${i} IndependentComponentsOff
|
||
|
volumeProperty3${i} IndependentComponentsOn
|
||
|
volumeProperty4${i} IndependentComponentsOff
|
||
|
|
||
|
volumeProperty0${i} SetColor rainbow
|
||
|
volumeProperty0${i} SetScalarOpacity rampPoint2
|
||
|
volumeProperty0${i} SetGradientOpacity constant1
|
||
|
|
||
|
volumeProperty1${i} SetColor rainbow
|
||
|
volumeProperty1${i} SetScalarOpacity rampPoint2
|
||
|
volumeProperty1${i} SetGradientOpacity constant1
|
||
|
|
||
|
volumeProperty2${i} SetColor rainbow
|
||
|
volumeProperty2${i} SetScalarOpacity rampPoint2
|
||
|
volumeProperty2${i} SetGradientOpacity constant1
|
||
|
|
||
|
volumeProperty3${i} SetColor 0 red
|
||
|
volumeProperty3${i} SetColor 1 green
|
||
|
volumeProperty3${i} SetColor 2 blue
|
||
|
volumeProperty3${i} SetColor 3 yellow
|
||
|
volumeProperty3${i} SetScalarOpacity 0 rampPoint2
|
||
|
volumeProperty3${i} SetScalarOpacity 1 rampPoint2
|
||
|
volumeProperty3${i} SetScalarOpacity 2 rampPoint2
|
||
|
volumeProperty3${i} SetScalarOpacity 3 rampPoint2
|
||
|
volumeProperty3${i} SetGradientOpacity 0 constant1
|
||
|
volumeProperty3${i} SetGradientOpacity 1 constant1
|
||
|
volumeProperty3${i} SetGradientOpacity 2 constant1
|
||
|
volumeProperty3${i} SetGradientOpacity 3 constant1
|
||
|
volumeProperty3${i} SetComponentWeight 0 1
|
||
|
volumeProperty3${i} SetComponentWeight 1 1
|
||
|
volumeProperty3${i} SetComponentWeight 2 1
|
||
|
volumeProperty3${i} SetComponentWeight 3 1
|
||
|
|
||
|
volumeProperty4${i} SetColor rainbow
|
||
|
volumeProperty4${i} SetScalarOpacity rampPoint2
|
||
|
volumeProperty4${i} SetGradientOpacity constant1
|
||
|
|
||
|
volumeProperty${i}2 ShadeOn
|
||
|
volumeProperty${i}4 ShadeOn 0
|
||
|
volumeProperty${i}4 ShadeOn 1
|
||
|
volumeProperty${i}4 ShadeOn 2
|
||
|
volumeProperty${i}4 ShadeOn 3
|
||
|
}
|
||
|
|
||
|
volumeProperty00 SetScalarOpacity ramp1
|
||
|
volumeProperty10 SetScalarOpacity ramp1
|
||
|
volumeProperty20 SetScalarOpacity ramp1
|
||
|
volumeProperty30 SetScalarOpacity 0 surface
|
||
|
volumeProperty30 SetScalarOpacity 1 surface
|
||
|
volumeProperty30 SetScalarOpacity 2 surface
|
||
|
volumeProperty30 SetScalarOpacity 3 surface
|
||
|
volumeProperty40 SetScalarOpacity ramp1
|
||
|
|
||
|
volumeProperty02 SetScalarOpacity surface
|
||
|
volumeProperty12 SetScalarOpacity surface
|
||
|
volumeProperty22 SetScalarOpacity surface
|
||
|
volumeProperty32 SetScalarOpacity 0 surface
|
||
|
volumeProperty32 SetScalarOpacity 1 surface
|
||
|
volumeProperty32 SetScalarOpacity 2 surface
|
||
|
volumeProperty32 SetScalarOpacity 3 surface
|
||
|
volumeProperty42 SetScalarOpacity surface
|
||
|
|
||
|
volumeProperty04 SetScalarOpacity surface
|
||
|
volumeProperty14 SetScalarOpacity surface
|
||
|
volumeProperty24 SetScalarOpacity surface
|
||
|
volumeProperty34 SetScalarOpacity 0 surface
|
||
|
volumeProperty34 SetScalarOpacity 1 surface
|
||
|
volumeProperty34 SetScalarOpacity 2 surface
|
||
|
volumeProperty34 SetScalarOpacity 3 surface
|
||
|
volumeProperty44 SetScalarOpacity surface
|
||
|
|
||
|
volumeProperty03 SetGradientOpacity gop
|
||
|
volumeProperty13 SetGradientOpacity gop
|
||
|
volumeProperty23 SetGradientOpacity gop
|
||
|
volumeProperty33 SetGradientOpacity 0 gop
|
||
|
volumeProperty33 SetGradientOpacity 2 gop
|
||
|
volumeProperty43 SetGradientOpacity gop
|
||
|
|
||
|
volumeProperty33 SetScalarOpacity 0 ramp1
|
||
|
volumeProperty33 SetScalarOpacity 2 ramp1
|
||
|
|
||
|
volumeProperty04 SetGradientOpacity gop
|
||
|
volumeProperty14 SetGradientOpacity gop
|
||
|
volumeProperty24 SetGradientOpacity gop
|
||
|
volumeProperty34 SetGradientOpacity 0 gop
|
||
|
volumeProperty34 SetGradientOpacity 2 gop
|
||
|
volumeProperty44 SetGradientOpacity gop
|
||
|
|
||
|
renWin Render
|
||
|
|
||
|
[ren1 GetActiveCamera] Dolly 1.3
|
||
|
[ren1 GetActiveCamera] Azimuth 15
|
||
|
[ren1 GetActiveCamera] Elevation 5
|
||
|
ren1 ResetCameraClippingRange
|
||
|
|
||
|
wm withdraw .
|
||
|
|
||
|
iren Initialize
|