VTK
vtkDelaunay2D.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkDelaunay2D.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 =========================================================================*/
131 #ifndef vtkDelaunay2D_h
132 #define vtkDelaunay2D_h
133 
134 #include "vtkFiltersCoreModule.h" // For export macro
135 #include "vtkPolyDataAlgorithm.h"
136 
138 class vtkCellArray;
139 class vtkIdList;
140 class vtkPointSet;
141 
142 #define VTK_DELAUNAY_XY_PLANE 0
143 #define VTK_SET_TRANSFORM_PLANE 1
144 #define VTK_BEST_FITTING_PLANE 2
145 
146 class VTKFILTERSCORE_EXPORT vtkDelaunay2D : public vtkPolyDataAlgorithm
147 {
148 public:
150  void PrintSelf(ostream& os, vtkIndent indent) override;
151 
156  static vtkDelaunay2D *New();
157 
167  void SetSourceData(vtkPolyData *);
168 
177  void SetSourceConnection(vtkAlgorithmOutput *algOutput);
178 
182  vtkPolyData *GetSource();
183 
185 
191  vtkSetClampMacro(Alpha,double,0.0,VTK_DOUBLE_MAX);
192  vtkGetMacro(Alpha,double);
194 
196 
201  vtkSetClampMacro(Tolerance,double,0.0,1.0);
202  vtkGetMacro(Tolerance,double);
204 
206 
210  vtkSetClampMacro(Offset,double,0.75,VTK_DOUBLE_MAX);
211  vtkGetMacro(Offset,double);
213 
215 
221  vtkSetMacro(BoundingTriangulation,vtkTypeBool);
222  vtkGetMacro(BoundingTriangulation,vtkTypeBool);
223  vtkBooleanMacro(BoundingTriangulation,vtkTypeBool);
225 
227 
237  virtual void SetTransform(vtkAbstractTransform*);
238  vtkGetObjectMacro(Transform, vtkAbstractTransform);
240 
242 
250  vtkSetClampMacro(ProjectionPlaneMode,int,
252  vtkGetMacro(ProjectionPlaneMode,int);
254 
261  static vtkAbstractTransform* ComputeBestFittingPlane(vtkPointSet *input);
262 
263 protected:
264  vtkDelaunay2D();
265  ~vtkDelaunay2D() override;
266 
268 
269  double Alpha;
270  double Tolerance;
272  double Offset;
273 
275 
276  int ProjectionPlaneMode; //selects the plane in 3D where the Delaunay triangulation will be computed.
277 
278 private:
279  vtkPolyData *Mesh; //the created mesh
280  double *Points; //the raw points in double precision
281  void SetPoint(vtkIdType id, double *x)
282  {vtkIdType idx=3*id;
283  this->Points[idx] = x[0];
284  this->Points[idx+1] = x[1];
285  this->Points[idx+2] = x[2];
286  }
287 
288  void GetPoint(vtkIdType id, double x[3])
289  {double *ptr = this->Points + 3*id;
290  x[0] = *ptr++;
291  x[1] = *ptr++;
292  x[2] = *ptr;
293  }
294 
295  int NumberOfDuplicatePoints;
296  int NumberOfDegeneracies;
297 
298  int *RecoverBoundary(vtkPolyData *source);
299  int RecoverEdge(vtkPolyData* source, vtkIdType p1, vtkIdType p2);
300  void FillPolygons(vtkCellArray *polys, int *triUse);
301 
302  int InCircle (double x[3], double x1[3], double x2[3], double x3[3]);
303  vtkIdType FindTriangle(double x[3], vtkIdType ptIds[3], vtkIdType tri,
304  double tol, vtkIdType nei[3], vtkIdList *neighbors);
305  void CheckEdge(vtkIdType ptId, double x[3], vtkIdType p1, vtkIdType p2,
306  vtkIdType tri, bool recursive);
307 
308  int FillInputPortInformation(int, vtkInformation*) override;
309 
310 private:
311  vtkDelaunay2D(const vtkDelaunay2D&) = delete;
312  void operator=(const vtkDelaunay2D&) = delete;
313 };
314 
315 #endif
#define VTK_DOUBLE_MAX
Definition: vtkType.h:169
Store vtkAlgorithm input/output information.
virtual int RequestData(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector)
This is called by the superclass.
abstract class for specifying dataset behavior
Definition: vtkPointSet.h:42
int vtkIdType
Definition: vtkType.h:347
concrete dataset represents vertices, lines, polygons, and triangle strips
Definition: vtkPolyData.h:85
void GetPoint(const int i, const int j, const int k, double pnt[3])
Proxy object to connect input/output ports.
static vtkPolyDataAlgorithm * New()
int vtkTypeBool
Definition: vtkABI.h:69
Superclass for algorithms that produce only polydata as output.
a simple class to control print indentation
Definition: vtkIndent.h:39
list of point or cell ids
Definition: vtkIdList.h:36
superclass for all geometric transformations
vtkAbstractTransform * Transform
#define VTK_BEST_FITTING_PLANE
boost::graph_traits< vtkGraph * >::vertex_descriptor source(boost::graph_traits< vtkGraph * >::edge_descriptor e, vtkGraph *)
object to represent cell connectivity
Definition: vtkCellArray.h:50
create 2D Delaunay triangulation of input points
vtkTypeBool BoundingTriangulation
int FillInputPortInformation(int port, vtkInformation *info) override
Fill the input port information objects for this algorithm.
Store zero or more vtkInformation instances.
#define VTK_DELAUNAY_XY_PLANE
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
Transform
Definition: ADIOSDefs.h:40