VTK  9.0.1
vtkLODProp3D.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkLODProp3D.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 =========================================================================*/
30 #ifndef vtkLODProp3D_h
31 #define vtkLODProp3D_h
32 
33 #include "vtkProp3D.h"
34 #include "vtkRenderingCoreModule.h" // For export macro
35 
36 class vtkRenderer;
37 class vtkMapper;
40 class vtkImageMapper3D;
41 class vtkProperty;
42 class vtkVolumeProperty;
43 class vtkImageProperty;
44 class vtkTexture;
45 class vtkLODProp3DCallback;
46 
47 typedef struct
48 {
51  int ID;
52  double EstimatedTime;
53  int State;
54  double Level;
56 
57 class VTKRENDERINGCORE_EXPORT vtkLODProp3D : public vtkProp3D
58 {
59 public:
63  static vtkLODProp3D* New();
64 
65  vtkTypeMacro(vtkLODProp3D, vtkProp3D);
66  void PrintSelf(ostream& os, vtkIndent indent) override;
67 
71  double* GetBounds() VTK_SIZEHINT(6) override;
72  void GetBounds(double bounds[6]) { this->vtkProp3D::GetBounds(bounds); }
73 
75 
84  int AddLOD(vtkMapper* m, vtkProperty* p, vtkProperty* back, vtkTexture* t, double time);
85  int AddLOD(vtkMapper* m, vtkProperty* p, vtkTexture* t, double time);
86  int AddLOD(vtkMapper* m, vtkProperty* p, vtkProperty* back, double time);
87  int AddLOD(vtkMapper* m, vtkProperty* p, double time);
88  int AddLOD(vtkMapper* m, vtkTexture* t, double time);
89  int AddLOD(vtkMapper* m, double time);
90  int AddLOD(vtkAbstractVolumeMapper* m, vtkVolumeProperty* p, double time);
91  int AddLOD(vtkAbstractVolumeMapper* m, double time);
92  int AddLOD(vtkImageMapper3D* m, vtkImageProperty* p, double time);
93  int AddLOD(vtkImageMapper3D* m, double time);
95 
97 
100  vtkGetMacro(NumberOfLODs, int);
102 
104 
109  vtkGetMacro(CurrentIndex, int);
111 
116  void RemoveLOD(int id);
117 
119 
125  void SetLODProperty(int id, vtkProperty* p);
126  void GetLODProperty(int id, vtkProperty** p);
127  void SetLODProperty(int id, vtkVolumeProperty* p);
128  void GetLODProperty(int id, vtkVolumeProperty** p);
129  void SetLODProperty(int id, vtkImageProperty* p);
130  void GetLODProperty(int id, vtkImageProperty** p);
132 
134 
140  void SetLODMapper(int id, vtkMapper* m);
141  void GetLODMapper(int id, vtkMapper** m);
142  void SetLODMapper(int id, vtkAbstractVolumeMapper* m);
143  void GetLODMapper(int id, vtkAbstractVolumeMapper** m);
144  void SetLODMapper(int id, vtkImageMapper3D* m);
145  void GetLODMapper(int id, vtkImageMapper3D** m);
147 
153  vtkAbstractMapper3D* GetLODMapper(int id);
154 
156 
160  void SetLODBackfaceProperty(int id, vtkProperty* t);
161  void GetLODBackfaceProperty(int id, vtkProperty** t);
163 
165 
169  void SetLODTexture(int id, vtkTexture* t);
170  void GetLODTexture(int id, vtkTexture** t);
172 
174 
179  void EnableLOD(int id);
180  void DisableLOD(int id);
181  int IsLODEnabled(int id);
183 
185 
193  void SetLODLevel(int id, double level);
194  double GetLODLevel(int id);
195  double GetLODIndexLevel(int index);
197 
199 
204  double GetLODEstimatedRenderTime(int id);
205  double GetLODIndexEstimatedRenderTime(int index);
207 
209 
214  vtkSetClampMacro(AutomaticLODSelection, vtkTypeBool, 0, 1);
215  vtkGetMacro(AutomaticLODSelection, vtkTypeBool);
216  vtkBooleanMacro(AutomaticLODSelection, vtkTypeBool);
218 
220 
224  vtkSetMacro(SelectedLODID, int);
225  vtkGetMacro(SelectedLODID, int);
227 
231  int GetLastRenderedLODID();
232 
236  int GetPickLODID(void);
237 
239 
244  void GetActors(vtkPropCollection*) override;
245  void GetVolumes(vtkPropCollection*) override;
247 
249 
253  void SetSelectedPickLODID(int id);
254  vtkGetMacro(SelectedPickLODID, int);
256 
258 
263  vtkSetClampMacro(AutomaticPickLODSelection, vtkTypeBool, 0, 1);
264  vtkGetMacro(AutomaticPickLODSelection, vtkTypeBool);
265  vtkBooleanMacro(AutomaticPickLODSelection, vtkTypeBool);
267 
271  void ShallowCopy(vtkProp* prop) override;
272 
274 
277  int RenderOpaqueGeometry(vtkViewport* viewport) override;
279  int RenderVolumetricGeometry(vtkViewport* ren) override;
281 
286 
292  void ReleaseGraphicsResources(vtkWindow*) override;
293 
299  void SetAllocatedRenderTime(double t, vtkViewport* vp) override;
300 
307  void RestoreEstimatedRenderTime() override;
308 
313  void AddEstimatedRenderTime(double t, vtkViewport* vp) override;
314 
315 protected:
316  vtkLODProp3D();
317  ~vtkLODProp3D() override;
318 
319  int GetAutomaticPickPropIndex(void);
320 
321  // Assumes that SelectedLODIndex has already been validated:
322  void UpdateKeysForSelectedProp();
323 
328 
329  int GetNextEntryIndex();
330  int ConvertIDToIndex(int id);
332 
337  vtkLODProp3DCallback* PickCallback;
338 
339 private:
340  vtkLODProp3D(const vtkLODProp3D&) = delete;
341  void operator=(const vtkLODProp3D&) = delete;
342 };
343 
344 #endif
vtkTypeBool AutomaticLODSelection
Definition: vtkLODProp3D.h:333
abstract superclass for all actors, volumes and annotations
Definition: vtkProp.h:47
vtkProp3D * Prop3D
Definition: vtkLODProp3D.h:49
double * GetBounds() override=0
Return a reference to the Prop3D's composite transform.
abstract specification for Viewports
Definition: vtkViewport.h:44
represent surface properties of a geometric object
Definition: vtkProperty.h:61
vtkLODProp3DEntry * LODs
Definition: vtkLODProp3D.h:324
virtual int RenderOpaqueGeometry(vtkViewport *)
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE DO NOT USE THESE METHODS OUTSIDE OF THE RENDE...
Definition: vtkProp.h:215
virtual vtkTypeBool HasTranslucentPolygonalGeometry()
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE DO NOT USE THESE METHODS OUTSIDE OF THE RENDE...
Definition: vtkProp.h:279
virtual void SetAllocatedRenderTime(double t, vtkViewport *vtkNotUsed(v))
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE DO NOT USE THIS METHOD OUTSIDE OF THE RENDERI...
Definition: vtkProp.h:372
image display properties
Abstract class for a volume mapper.
abstract specification for renderers
Definition: vtkRenderer.h:58
represents an 3D object for placement in a rendered scene
Definition: vtkProp3D.h:43
virtual void AddEstimatedRenderTime(double t, vtkViewport *vtkNotUsed(vp))
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE DO NOT USE THIS METHOD OUTSIDE OF THE RENDERI...
Definition: vtkProp.h:356
int SelectedPickLODID
Definition: vtkLODProp3D.h:335
an ordered list of Props
int vtkTypeBool
Definition: vtkABI.h:69
virtual void ReleaseGraphicsResources(vtkWindow *)
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE Release any graphics resources that are being...
Definition: vtkProp.h:300
window superclass for vtkRenderWindow
Definition: vtkWindow.h:34
vtkTypeBool AutomaticPickLODSelection
Definition: vtkLODProp3D.h:336
vtkLODProp3DCallback * PickCallback
Definition: vtkLODProp3D.h:337
virtual int RenderVolumetricGeometry(vtkViewport *)
Definition: vtkProp.h:217
int SelectedLODIndex
Definition: vtkLODProp3D.h:331
a simple class to control print indentation
Definition: vtkIndent.h:33
abstract class for mapping images to the screen
void ShallowCopy(vtkProp *prop) override
Shallow copy of this vtkProp3D.
virtual void GetVolumes(vtkPropCollection *)
Definition: vtkProp.h:60
handles properties associated with a texture map
Definition: vtkTexture.h:65
abstract class specifies interface to map 3D data
#define VTK_SIZEHINT(...)
represents the common properties for rendering a volume.
abstract class specifies interface to map data to graphics primitives
Definition: vtkMapper.h:80
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
level of detail 3D prop
Definition: vtkLODProp3D.h:57
virtual int RenderTranslucentPolygonalGeometry(vtkViewport *)
Definition: vtkProp.h:216
virtual void RestoreEstimatedRenderTime()
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE DO NOT USE THESE METHODS OUTSIDE OF THE RENDE...
Definition: vtkProp.h:338
static vtkObject * New()
Create an object with Debug turned off, modified time initialized to zero, and reference counting on...
virtual void GetActors(vtkPropCollection *)
For some exporters and other other operations we must be able to collect all the actors or volumes...
Definition: vtkProp.h:58