VTK  9.0.1
vtkAdaptiveDataSetSurfaceFilter.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkAdaptiveDataSetSurfaceFilter.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 =========================================================================*/
33 #ifndef vtkAdaptiveDataSetSurfaceFilter_h
34 #define vtkAdaptiveDataSetSurfaceFilter_h
35 
36 #include "vtkFiltersHybridModule.h" // For export macro
37 #include "vtkGeometryFilter.h"
38 
39 class vtkBitArray;
40 class vtkCamera;
41 class vtkHyperTreeGrid;
42 class vtkRenderer;
43 
46 
47 class VTKFILTERSHYBRID_EXPORT vtkAdaptiveDataSetSurfaceFilter : public vtkGeometryFilter
48 {
49 public:
52  void PrintSelf(ostream&, vtkIndent) override;
53 
55 
58  void SetRenderer(vtkRenderer* ren);
59  vtkGetObjectMacro(Renderer, vtkRenderer);
61 
65  vtkMTimeType GetMTime() override;
66 
68 
71  vtkSetMacro(CircleSelection, bool);
72  vtkGetMacro(CircleSelection, bool);
74 
76 
81  vtkSetMacro(BBSelection, bool);
82  vtkGetMacro(BBSelection, bool);
84 
86 
89  vtkSetMacro(ViewPointDepend, bool);
90  vtkGetMacro(ViewPointDepend, bool);
92 
94 
97  vtkSetMacro(FixedLevelMax, int);
98  vtkGetMacro(FixedLevelMax, int);
100 
102 
107  vtkSetMacro(Scale, double);
108  vtkGetMacro(Scale, double);
110 
112 
117  vtkSetMacro(DynamicDecimateLevelMax, int);
118  vtkGetMacro(DynamicDecimateLevelMax, int);
120 
121 protected:
124 
125  int RequestData(vtkInformation* vtkNotUsed(request), vtkInformationVector** inputVector,
126  vtkInformationVector* outputVector) override;
127  int DataSetExecute(vtkDataObject* input, vtkPolyData* output) /*override*/;
128  int FillInputPortInformation(int port, vtkInformation* info) override;
129 
133  void ProcessTrees(vtkHyperTreeGrid* input, vtkPolyData* output);
134 
138  void RecursivelyProcessTreeNot3D(vtkHyperTreeGridNonOrientedGeometryCursor*, int);
139  void RecursivelyProcessTree3D(vtkHyperTreeGridNonOrientedVonNeumannSuperCursorLight*, int);
140 
144  void ProcessLeaf1D(vtkHyperTreeGridNonOrientedGeometryCursor*);
145 
149  void ProcessLeaf2D(vtkHyperTreeGridNonOrientedGeometryCursor*);
150 
155 
159  void AddFace(vtkIdType, const double*, const double*, int, unsigned int);
160 
163 
167  unsigned int Dimension;
168 
172  unsigned int Orientation;
173 
178 
183 
188 
193 
197  unsigned int Axis1;
198 
202  unsigned int Axis2;
203 
207  int LevelMax;
208 
213 
217  int LastRendererSize[2];
218 
223 
227  double LastCameraFocalPoint[3];
228 
233 
237  double WindowBounds[4];
238 
243 
247  double Radius;
248 
253 
254 #ifndef NDEBUG
255 
259  long int NbRejectByBB;
260 #endif
261 
266 
270  double Scale;
271 
276 
277 private:
279  void operator=(const vtkAdaptiveDataSetSurfaceFilter&) = delete;
280 };
281 
282 #endif // vtkAdaptiveDataSetSurfaceFilter_h
long int NbRejectByCircle
Effect of options selection.
unsigned int Axis2
Second axis parameter for adaptive view.
static vtkGeometryFilter * New()
Store vtkAlgorithm input/output information.
vtkTypeUInt32 vtkMTimeType
Definition: vtkType.h:293
A dataset containing a grid of vtkHyperTree instances arranged as a rectilinear grid.
unsigned int Dimension
Dimension of input grid.
abstract specification for renderers
Definition: vtkRenderer.h:67
unsigned int Axis1
First axis parameter for adaptive view.
vtkMTimeType GetMTime() override
Return the MTime also considering the locator.
int vtkIdType
Definition: vtkType.h:338
concrete dataset represents vertices, lines, polygons, and triangle strips
Definition: vtkPolyData.h:84
unsigned int Orientation
Orientation of input grid when dimension < 3.
bool ViewPointDepend
JB Activation de la dependance au point de vue.
int FixedLevelMax
JB Forced, fixed the level depth, ignored automatic determination.
vtkCellArray * Cells
Storage for cells of output unstructured mesh.
Adaptively extract dataset surface.
bool BBSelection
Product cell when in nounding box selection.
bool ParallelProjection
Parallel projection parameter for adaptive view.
int FillInputPortInformation(int port, vtkInformation *info) override
Fill the input port information objects for this algorithm.
double Radius
Radius parameter for adaptive view.
a simple class to control print indentation
Definition: vtkIndent.h:33
a virtual camera for 3D rendering
Definition: vtkCamera.h:45
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
This is called by the superclass.
represent and manipulate attribute data in a dataset
double LastCameraParallelScale
Last camera parallel scale for adaptive view.
vtkPoints * Points
Storage for points of output unstructured mesh.
object to represent cell connectivity
Definition: vtkCellArray.h:179
double Scale
Scale factor for adaptive view.
dynamic, self-adjusting array of bits
Definition: vtkBitArray.h:33
int DynamicDecimateLevelMax
JB Decimate level max after automatic determination.
Store zero or more vtkInformation instances.
extract geometry from data (or convert data to polygonal type)
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkRenderer * Renderer
Pointer to the renderer in use.
general representation of visualization data
Definition: vtkDataObject.h:59
int LevelMax
Maximum depth parameter for adaptive view.
bool CircleSelection
Product cell when in circle selection.
represent and manipulate 3D points
Definition: vtkPoints.h:33