VTK  9.1.0
vtkUnstructuredGridVolumeRayCastMapper.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkUnstructuredGridVolumeRayCastMapper.h
5
6 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7 All rights reserved.
8 See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9
10 This software is distributed WITHOUT ANY WARRANTY; without even
11 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12 PURPOSE. See the above copyright notice for more information.
13
14=========================================================================*/
15
35#ifndef vtkUnstructuredGridVolumeRayCastMapper_h
36#define vtkUnstructuredGridVolumeRayCastMapper_h
37
38#include "vtkRenderingVolumeModule.h" // For export macro
40
41class vtkDoubleArray;
42class vtkIdList;
45class vtkRenderer;
46class vtkTimerLog;
50class vtkVolume;
51
52class VTKRENDERINGVOLUME_EXPORT vtkUnstructuredGridVolumeRayCastMapper
54{
55public:
58 void PrintSelf(ostream& os, vtkIndent indent) override;
59
61
66 vtkSetClampMacro(ImageSampleDistance, float, 0.1f, 100.0f);
67 vtkGetMacro(ImageSampleDistance, float);
69
71
75 vtkSetClampMacro(MinimumImageSampleDistance, float, 0.1f, 100.0f);
76 vtkGetMacro(MinimumImageSampleDistance, float);
78
80
84 vtkSetClampMacro(MaximumImageSampleDistance, float, 0.1f, 100.0f);
85 vtkGetMacro(MaximumImageSampleDistance, float);
87
89
95 vtkSetClampMacro(AutoAdjustSampleDistances, vtkTypeBool, 0, 1);
96 vtkGetMacro(AutoAdjustSampleDistances, vtkTypeBool);
97 vtkBooleanMacro(AutoAdjustSampleDistances, vtkTypeBool);
99
101
105 vtkSetMacro(NumberOfThreads, int);
106 vtkGetMacro(NumberOfThreads, int);
108
110
114 vtkSetClampMacro(IntermixIntersectingGeometry, vtkTypeBool, 0, 1);
115 vtkGetMacro(IntermixIntersectingGeometry, vtkTypeBool);
116 vtkBooleanMacro(IntermixIntersectingGeometry, vtkTypeBool);
118
120
124 vtkGetObjectMacro(RayCastFunction, vtkUnstructuredGridVolumeRayCastFunction);
126
128
133 vtkGetObjectMacro(RayIntegrator, vtkUnstructuredGridVolumeRayIntegrator);
135
140 void Render(vtkRenderer*, vtkVolume*) override;
141
149
150 vtkGetVectorMacro(ImageInUseSize, int, 2);
151 vtkGetVectorMacro(ImageOrigin, int, 2);
152 vtkGetVectorMacro(ImageViewportSize, int, 2);
153
154 void CastRays(int threadID, int threadCount);
155
156protected:
159
164
167
169
170 // This is how big the image would be if it covered the entire viewport
171 int ImageViewportSize[2];
172
173 // This is how big the allocated memory for image is. This may be bigger
174 // or smaller than ImageFullSize - it will be bigger if necessary to
175 // ensure a power of 2, it will be smaller if the volume only covers a
176 // small region of the viewport
177 int ImageMemorySize[2];
178
179 // This is the size of subregion in ImageSize image that we are using for
180 // the current image. Since ImageSize is a power of 2, there is likely
181 // wasted space in it. This number will be used for things such as clearing
182 // the image if necessary.
183 int ImageInUseSize[2];
184
185 // This is the location in ImageFullSize image where our ImageSize image
186 // is located.
187 int ImageOrigin[2];
188
189 // This is the allocated image
190 unsigned char* Image;
191
197
198 void StoreRenderTime(vtkRenderer* ren, vtkVolume* vol, float t);
200
202
203 float* ZBuffer;
204 int ZBufferSize[2];
205 int ZBufferOrigin[2];
206
207 // Get the ZBuffer value corresponding to location (x,y) where (x,y)
208 // are indexing into the ImageInUse image. This must be converted to
209 // the zbuffer image coordinates. Nearest neighbor value is returned.
210 double GetZBufferValue(int x, int y);
211
213
218
223
226
229
230private:
232 void operator=(const vtkUnstructuredGridVolumeRayCastMapper&) = delete;
233};
234
235#endif
abstract superclass for arrays of numeric data
Definition: vtkDataArray.h:59
dynamic, self-adjusting array of double
list of point or cell ids
Definition: vtkIdList.h:40
a simple class to control print indentation
Definition: vtkIndent.h:43
A class for performing multithreaded execution.
helper class that draws the image to the screen
abstract specification for renderers
Definition: vtkRenderer.h:73
Timer support and logging.
Definition: vtkTimerLog.h:99
Abstract class for an unstructured grid volume mapper.
vtkUnstructuredGridVolumeRayCastIterator is a superclass for iterating over the intersections of a vi...
A software mapper for unstructured volumes.
vtkUnstructuredGridVolumeRayIntegrator * RealRayIntegrator
void Render(vtkRenderer *, vtkVolume *) override
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE Initialize rendering for this volume.
static vtkUnstructuredGridVolumeRayCastMapper * New()
vtkUnstructuredGridVolumeRayIntegrator * RayIntegrator
vtkUnstructuredGridVolumeRayCastIterator ** RayCastIterators
virtual void SetRayCastFunction(vtkUnstructuredGridVolumeRayCastFunction *f)
Set/Get the helper class for casting rays.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
void CastRays(int threadID, int threadCount)
void ReleaseGraphicsResources(vtkWindow *) override
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE Release any graphics resources that are being...
vtkUnstructuredGridVolumeRayCastFunction * RayCastFunction
void StoreRenderTime(vtkRenderer *ren, vtkVolume *vol, float t)
float RetrieveRenderTime(vtkRenderer *ren, vtkVolume *vol)
virtual void SetRayIntegrator(vtkUnstructuredGridVolumeRayIntegrator *ri)
Set/Get the helper class for integrating rays.
double GetMinimumBoundsDepth(vtkRenderer *ren, vtkVolume *vol)
a superclass for volume ray integration functions
represents a volume (data & properties) in a rendered scene
Definition: vtkVolume.h:54
window superclass for vtkRenderWindow
Definition: vtkWindow.h:45
int vtkTypeBool
Definition: vtkABI.h:69