102#ifndef vtkFixedPointVolumeRayCastMapper_h
103#define vtkFixedPointVolumeRayCastMapper_h
105#include "vtkRenderingVolumeModule.h"
106#include "vtkThreads.h"
109#define VTKKW_FP_SHIFT 15
110#define VTKKW_FPMM_SHIFT 17
111#define VTKKW_FP_MASK 0x7fff
112#define VTKKW_FP_SCALE 32767.0
114VTK_ABI_NAMESPACE_BEGIN
155 vtkSetMacro(SampleDistance,
float);
156 vtkGetMacro(SampleDistance,
float);
167 vtkSetMacro(InteractiveSampleDistance,
float);
168 vtkGetMacro(InteractiveSampleDistance,
float);
179 vtkSetClampMacro(ImageSampleDistance,
float, 0.1f, 100.0f);
180 vtkGetMacro(ImageSampleDistance,
float);
188 vtkSetClampMacro(MinimumImageSampleDistance,
float, 0.1f, 100.0f);
189 vtkGetMacro(MinimumImageSampleDistance,
float);
197 vtkSetClampMacro(MaximumImageSampleDistance,
float, 0.1f, 100.0f);
198 vtkGetMacro(MaximumImageSampleDistance,
float);
225 vtkSetClampMacro(LockSampleDistanceToInputSpacing,
vtkTypeBool, 0, 1);
245 vtkSetClampMacro(IntermixIntersectingGeometry,
vtkTypeBool, 0, 1);
268 unsigned int ToFixedPointPosition(
float val);
269 void ToFixedPointPosition(
float in[3],
unsigned int out[3]);
270 unsigned int ToFixedPointDirection(
float dir);
271 void ToFixedPointDirection(
float in[3],
unsigned int out[3]);
272 void FixedPointIncrement(
unsigned int position[3],
unsigned int increment[3]);
273 void GetFloatTripleFromPointer(
float v[3],
float* ptr);
274 void GetUIntTripleFromPointer(
unsigned int v[3],
unsigned int* ptr);
275 void ShiftVectorDown(
unsigned int in[3],
unsigned int out[3]);
276 int CheckMinMaxVolumeFlag(
unsigned int pos[3],
int c);
277 int CheckMIPMinMaxVolumeFlag(
unsigned int pos[3],
int c,
unsigned short maxIdx,
int flip);
279 void LookupColorUC(
unsigned short* colorTable,
unsigned short* scalarOpacityTable,
280 unsigned short index,
unsigned char color[4]);
281 void LookupDependentColorUC(
unsigned short* colorTable,
unsigned short* scalarOpacityTable,
282 unsigned short index[4],
int components,
unsigned char color[4]);
283 void LookupAndCombineIndependentColorsUC(
unsigned short* colorTable[4],
284 unsigned short* scalarOpacityTable[4],
unsigned short index[4],
float weights[4],
285 int components,
unsigned char color[4]);
286 int CheckIfCropped(
unsigned int pos[3]);
294 vtkGetVectorMacro(TableShift,
float, 4);
295 vtkGetVectorMacro(TableScale,
float, 4);
296 vtkGetMacro(ShadingRequired,
int);
297 vtkGetMacro(GradientOpacityRequired,
int);
313 int x,
int y,
unsigned int pos[3],
unsigned int dir[3],
unsigned int* numSteps);
337 double viewDirection[3],
double viewUp[3]);
347 return this->RetrieveRenderTime(ren, vol);
365 vtkSetMacro(FinalColorWindow,
float);
366 vtkGetMacro(FinalColorWindow,
float);
367 vtkSetMacro(FinalColorLevel,
float);
368 vtkGetMacro(FinalColorLevel,
float);
374 vtkGetMacro(FlipMIPComparison,
int);
408 void ComputeMatrices(
double inputOrigin[3],
double inputSpacing[3],
int inputExtent[6],
457 int SavedColorChannels[4];
458 float SavedScalarOpacityDistance[4];
468 unsigned short ColorTable[4][32768 * 3];
469 unsigned short ScalarOpacityTable[4][32768];
470 unsigned short GradientOpacityTable[4][256];
475 float GradientMagnitudeScale[4];
476 float GradientMagnitudeShift[4];
491 unsigned short DiffuseShadingTable[4][65536 * 3];
492 unsigned short SpecularShadingTable[4][65536 * 3];
504 double rayStart[3],
double rayEnd[3],
float rayDirection[3],
double bounds[6]);
514 double rayStart[3],
double rayEnd[3],
int numClippingPlanes,
float* clippingPlanes);
516 unsigned int FixedPointCroppingRegionPlanes[6];
517 unsigned int CroppingRegionMask[27];
531 float ViewToVoxelsArray[16];
532 float WorldToVoxelsArray[16];
533 float VoxelsToWorldArray[16];
535 double CroppingBounds[6];
540 double SavedSpacing[3];
544 int MinMaxVolumeSize[4];
580 return ((dir < 0.0) ? (
static_cast<unsigned int>(-dir *
VTKKW_FP_SCALE + 0.5))
581 : (0x80000000 +
static_cast<unsigned int>(dir *
VTKKW_FP_SCALE + 0.5)));
585 float in[3],
unsigned int out[3])
587 out[0] = ((in[0] < 0.0) ? (
static_cast<unsigned int>(-in[0] *
VTKKW_FP_SCALE + 0.5))
588 : (0x80000000 +
static_cast<unsigned int>(in[0] *
VTKKW_FP_SCALE + 0.5)));
589 out[1] = ((in[1] < 0.0) ? (
static_cast<unsigned int>(-in[1] *
VTKKW_FP_SCALE + 0.5))
590 : (0x80000000 +
static_cast<unsigned int>(in[1] *
VTKKW_FP_SCALE + 0.5)));
591 out[2] = ((in[2] < 0.0) ? (
static_cast<unsigned int>(-in[2] *
VTKKW_FP_SCALE + 0.5))
592 : (0x80000000 +
static_cast<unsigned int>(in[2] *
VTKKW_FP_SCALE + 0.5)));
596 unsigned int position[3],
unsigned int increment[3])
598 if (increment[0] & 0x80000000)
600 position[0] += (increment[0] & 0x7fffffff);
604 position[0] -= increment[0];
606 if (increment[1] & 0x80000000)
608 position[1] += (increment[1] & 0x7fffffff);
612 position[1] -= increment[1];
614 if (increment[2] & 0x80000000)
616 position[2] += (increment[2] & 0x7fffffff);
620 position[2] -= increment[2];
632 unsigned int v[3],
unsigned int* ptr)
640 unsigned int in[3],
unsigned int out[3])
651 mmpos[1] *
static_cast<vtkIdType>(this->MinMaxVolumeSize[0]) + mmpos[0]) +
654 return ((*(this->
MinMaxVolume + 3 * offset + 2)) & 0x00ff);
658 unsigned int mmpos[3],
int c,
unsigned short maxIdx,
int flip)
662 mmpos[1] *
static_cast<vtkIdType>(this->MinMaxVolumeSize[0]) + mmpos[0]) +
673 return (*(this->
MinMaxVolume + 3 * offset + 1) > maxIdx);
683 unsigned short* scalarOpacityTable,
unsigned short index,
unsigned char color[4])
685 unsigned short alpha = scalarOpacityTable[index];
686 color[0] =
static_cast<unsigned char>(
687 (colorTable[3 * index] * alpha + 0x7fff) >> (2 *
VTKKW_FP_SHIFT - 8));
688 color[1] =
static_cast<unsigned char>(
689 (colorTable[3 * index + 1] * alpha + 0x7fff) >> (2 *
VTKKW_FP_SHIFT - 8));
690 color[2] =
static_cast<unsigned char>(
691 (colorTable[3 * index + 2] * alpha + 0x7fff) >> (2 *
VTKKW_FP_SHIFT - 8));
692 color[3] =
static_cast<unsigned char>(alpha >> (
VTKKW_FP_SHIFT - 8));
696 unsigned short* scalarOpacityTable,
unsigned short index[4],
int components,
697 unsigned char color[4])
699 unsigned short alpha;
703 alpha = scalarOpacityTable[index[1]];
704 color[0] =
static_cast<unsigned char>(
705 (colorTable[3 * index[0]] * alpha + 0x7fff) >> (2 *
VTKKW_FP_SHIFT - 8));
706 color[1] =
static_cast<unsigned char>(
707 (colorTable[3 * index[0] + 1] * alpha + 0x7fff) >> (2 *
VTKKW_FP_SHIFT - 8));
708 color[2] =
static_cast<unsigned char>(
709 (colorTable[3 * index[0] + 2] * alpha + 0x7fff) >> (2 *
VTKKW_FP_SHIFT - 8));
710 color[3] =
static_cast<unsigned char>(alpha >> (
VTKKW_FP_SHIFT - 8));
713 alpha = scalarOpacityTable[index[3]];
714 color[0] =
static_cast<unsigned char>((index[0] * alpha + 0x7fff) >>
VTKKW_FP_SHIFT);
715 color[1] =
static_cast<unsigned char>((index[1] * alpha + 0x7fff) >>
VTKKW_FP_SHIFT);
716 color[2] =
static_cast<unsigned char>((index[2] * alpha + 0x7fff) >>
VTKKW_FP_SHIFT);
717 color[3] =
static_cast<unsigned char>(alpha >> (
VTKKW_FP_SHIFT - 8));
723 unsigned short* colorTable[4],
unsigned short* scalarOpacityTable[4],
unsigned short index[4],
724 float weights[4],
int components,
unsigned char color[4])
726 unsigned int tmp[4] = { 0, 0, 0, 0 };
728 for (
int i = 0; i < components; i++)
730 unsigned short alpha =
731 static_cast<unsigned short>(
static_cast<float>(scalarOpacityTable[i][index[i]]) * weights[i]);
732 tmp[0] +=
static_cast<unsigned char>(
733 ((colorTable[i][3 * index[i]]) * alpha + 0x7fff) >> (2 *
VTKKW_FP_SHIFT - 8));
734 tmp[1] +=
static_cast<unsigned char>(
735 ((colorTable[i][3 * index[i] + 1]) * alpha + 0x7fff) >> (2 *
VTKKW_FP_SHIFT - 8));
736 tmp[2] +=
static_cast<unsigned char>(
737 ((colorTable[i][3 * index[i] + 2]) * alpha + 0x7fff) >> (2 *
VTKKW_FP_SHIFT - 8));
738 tmp[3] +=
static_cast<unsigned char>(alpha >> (
VTKKW_FP_SHIFT - 8));
741 color[0] =
static_cast<unsigned char>((tmp[0] > 255) ? (255) : (tmp[0]));
742 color[1] =
static_cast<unsigned char>((tmp[1] > 255) ? (255) : (tmp[1]));
743 color[2] =
static_cast<unsigned char>((tmp[2] > 255) ? (255) : (tmp[2]));
744 color[3] =
static_cast<unsigned char>((tmp[3] > 255) ? (255) : (tmp[3]));
Defines a transfer function for mapping a property to an RGB color value.
abstract superclass for arrays of numeric data
encode a direction into a one or two byte value
Compute shading tables for encoded normals.
Use finite differences to estimate gradient.
helper class for a ray cast image
A helper that generates composite images for the volume ray cast mapper.
A helper that generates composite images for the volume ray cast mapper.
A helper that generates composite images for the volume ray cast mapper.
A helper that generates composite images for the volume ray cast mapper.
A helper that generates MIP images for the volume ray cast mapper.
A fixed point mapper for volumes.
void SetRayCastImage(vtkFixedPointRayCastImage *)
Set / Get the underlying image object.
vtkRayCastImageDisplayHelper * ImageDisplayHelper
vtkMatrix4x4 * ViewToWorldMatrix
vtkMatrix4x4 * ViewToVoxelsMatrix
vtkEncodedGradientShader * GradientShader
vtkFixedPointVolumeRayCastMIPHelper * MIPHelper
vtkFixedPointVolumeRayCastCompositeGOHelper * CompositeGOHelper
float OldImageSampleDistance
int ShouldUseNearestNeighborInterpolation(vtkVolume *vol)
void ReleaseGraphicsResources(vtkWindow *) override
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE Release any graphics resources that are being...
vtkMultiThreader * Threader
float RetrieveRenderTime(vtkRenderer *ren)
float MaximumImageSampleDistance
unsigned short * GetColorTable(int c)
unsigned short * GetSpecularShadingTable(int c)
float ImageSampleDistance
vtkTransform * VoxelsTransform
unsigned short * ContiguousGradientNormal
float MinimumImageSampleDistance
vtkFixedPointVolumeRayCastMapper()
vtkImageData * SavedMinMaxInput
void UpdateCroppingRegions()
void GetFloatTripleFromPointer(float v[3], float *ptr)
unsigned short * MinMaxVolume
unsigned char ** GradientMagnitude
void CaptureZBuffer(vtkRenderer *ren)
void ApplyFinalColorWindowLevel()
float ComputeRequiredImageSampleDistance(float desiredTime, vtkRenderer *ren)
What is the image sample distance required to achieve the desired time? A version of this method is p...
void ComputeRayInfo(int x, int y, unsigned int pos[3], unsigned int dir[3], unsigned int *numSteps)
vtkFixedPointVolumeRayCastCompositeShadeHelper * CompositeShadeHelper
unsigned short * GetScalarOpacityTable(int c)
vtkMatrix4x4 * VoxelsToWorldMatrix
vtkTimeStamp SavedGradientsMTime
unsigned short * GetGradientOpacityTable(int c)
vtkRenderWindow * RenderWindow
float MinimumViewDistance
void StoreRenderTime(vtkRenderer *ren, vtkVolume *vol, float t)
vtkFiniteDifferenceGradientEstimator * GradientEstimator
vtkFixedPointVolumeRayCastCompositeGOShadeHelper * CompositeGOShadeHelper
vtkTypeBool IntermixIntersectingGeometry
int ComputeRowBounds(vtkRenderer *ren, int imageFlag, int rowBoundsFlag, int inputExtent[6])
vtkTypeBool AutoAdjustSampleDistances
vtkImageData * MinMaxVolumeCache
float GetZBufferValue(int x, int y)
void DisplayRenderedImage(vtkRenderer *, vtkVolume *)
void FillInMaxGradientMagnitudes(int fullDim[3], int smallDim[3])
unsigned int ToFixedPointDirection(float dir)
vtkMatrix4x4 * VolumeMatrix
void InitializeRayInfo(vtkVolume *vol)
void SetNumberOfThreads(int num)
Set/Get the number of threads to use.
vtkImageData * SavedParametersInput
void Render(vtkRenderer *, vtkVolume *) override
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE Initialize rendering for this volume.
void ComputeGradients(vtkVolume *vol)
int UpdateShadingTable(vtkRenderer *ren, vtkVolume *vol)
void GetUIntTripleFromPointer(unsigned int v[3], unsigned int *ptr)
float ComputeRequiredImageSampleDistance(float desiredTime, vtkRenderer *ren, vtkVolume *vol)
What is the image sample distance required to achieve the desired time? A version of this method is p...
~vtkFixedPointVolumeRayCastMapper() override
float SavedSampleDistance
static vtkFixedPointVolumeRayCastMapper * New()
float GetEstimatedRenderTime(vtkRenderer *ren, vtkVolume *vol)
Get an estimate of the rendering time for a given volume / renderer.
float RetrieveRenderTime(vtkRenderer *ren, vtkVolume *vol)
int GradientOpacityRequired
int CheckMinMaxVolumeFlag(unsigned int pos[3], int c)
vtkFixedPointVolumeRayCastCompositeHelper * CompositeHelper
vtkTransform * PerspectiveTransform
unsigned int ToFixedPointPosition(float val)
int CheckMIPMinMaxVolumeFlag(unsigned int pos[3], int c, unsigned short maxIdx, int flip)
float GetEstimatedRenderTime(vtkRenderer *ren)
unsigned short * GetDiffuseShadingTable(int c)
vtkDirectionEncoder * DirectionEncoder
vtkMatrix4x4 * PerspectiveMatrix
unsigned char ** GetGradientMagnitude()
float InteractiveSampleDistance
friend VTK_THREAD_RETURN_TYPE vtkFPVRCMSwitchOnDataType(void *arg)
void PerSubVolumeInitialization(vtkRenderer *, vtkVolume *, int)
vtkImageData * SavedGradientsInput
vtkTimeStamp SavedParametersMTime
unsigned short ** GradientNormal
void ComputeMatrices(double inputOrigin[3], double inputSpacing[3], int inputExtent[6], vtkRenderer *ren, vtkVolume *vol)
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
void LookupColorUC(unsigned short *colorTable, unsigned short *scalarOpacityTable, unsigned short index, unsigned char color[4])
vtkTransform * VoxelsToViewTransform
void FixedPointIncrement(unsigned int position[3], unsigned int increment[3])
void LookupAndCombineIndependentColorsUC(unsigned short *colorTable[4], unsigned short *scalarOpacityTable[4], unsigned short index[4], float weights[4], int components, unsigned char color[4])
vtkMatrix4x4 * WorldToVoxelsMatrix
vtkVolumeRayCastSpaceLeapingImageFilter * SpaceLeapFilter
void PerVolumeInitialization(vtkRenderer *, vtkVolume *)
int ClipRayAgainstVolume(double rayStart[3], double rayEnd[3], float rayDirection[3], double bounds[6])
void CreateCanonicalView(vtkVolume *volume, vtkImageData *image, int blend_mode, double viewDirection[3], double viewUp[3])
int PerImageInitialization(vtkRenderer *, vtkVolume *, int, double *, double *, int *)
unsigned int FixedPointCroppingRegionPlanes[6]
vtkFixedPointRayCastImage * RayCastImage
float * TransformedClippingPlanes
vtkVolume ** RenderVolumeTable
void UpdateMinMaxVolume(vtkVolume *vol)
friend VTK_THREAD_RETURN_TYPE FixedPointVolumeRayCastMapper_CastRays(void *arg)
vtkDataArray * PreviousScalars
vtkRenderer ** RenderRendererTable
void ShiftVectorDown(unsigned int in[3], unsigned int out[3])
int UpdateColorTable(vtkVolume *vol)
int NumTransformedClippingPlanes
unsigned char * ContiguousGradientMagnitude
int ClipRayAgainstClippingPlanes(double rayStart[3], double rayEnd[3], int numClippingPlanes, float *clippingPlanes)
int GetNumberOfThreads()
Set/Get the number of threads to use.
int UpdateGradients(vtkVolume *vol)
vtkDataArray * CurrentScalars
vtkTypeBool LockSampleDistanceToInputSpacing
unsigned int CroppingRegionMask[27]
unsigned short ** GetGradientNormal()
void LookupDependentColorUC(unsigned short *colorTable, unsigned short *scalarOpacityTable, unsigned short index[4], int components, unsigned char color[4])
int CheckIfCropped(unsigned int pos[3])
int NumberOfGradientSlices
vtkMatrix4x4 * VoxelsToViewMatrix
topologically and geometrically regular array of data
a simple class to control print indentation
represent and manipulate 4x4 transformation matrices
A class for performing multithreaded execution.
Defines a 1D piecewise function.
maintain a list of planes
helper class that draws the image to the screen
create a window for renderers to draw into
abstract specification for renderers
record modification and/or execution time
Timer support and logging.
Abstract class for a volume mapper.
int CroppingRegionFlags
Cropping variables, and a method for converting the world coordinate cropping region planes to voxel ...
Builds the space leaping data structure.
represents a volume (data & properties) in a rendered scene
window superclass for vtkRenderWindow
VTK_THREAD_RETURN_TYPE vtkFPVRCMSwitchOnDataType(void *arg)
VTK_THREAD_RETURN_TYPE FixedPointVolumeRayCastMapper_CastRays(void *arg)