VTK  9.1.0
vtkConvexHull2D.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkConvexHull2D.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
48#ifndef vtkConvexHull2D_h
49#define vtkConvexHull2D_h
50
52#include "vtkRenderingAnnotationModule.h" // For export macro
53#include "vtkSmartPointer.h" // needed for ivars
54
55class vtkCoordinate;
56class vtkPoints;
57class vtkPolygon;
58class vtkPolyLine;
59class vtkRenderer;
60class vtkTransform;
62
63class VTKRENDERINGANNOTATION_EXPORT vtkConvexHull2D : public vtkPolyDataAlgorithm
64{
65public:
68 void PrintSelf(ostream& os, vtkIndent indent) override;
69
71
74 vtkGetMacro(ScaleFactor, double);
75 vtkSetMacro(ScaleFactor, double);
77
79
82 vtkGetMacro(Outline, bool);
83 vtkSetMacro(Outline, bool);
84 vtkBooleanMacro(Outline, bool);
86
88 {
89 BoundingRectangle = 0,
90 ConvexHull
91 };
92
94
97 vtkGetMacro(HullShape, int);
98 vtkSetClampMacro(HullShape, int, 0, 1);
100
102
106 vtkSetClampMacro(MinHullSizeInWorld, double, 0.0, VTK_DOUBLE_MAX);
107 vtkGetMacro(MinHullSizeInWorld, double);
109
111
115 vtkSetClampMacro(MinHullSizeInDisplay, int, 0, VTK_INT_MAX);
116 vtkGetMacro(MinHullSizeInDisplay, int);
118
120
123 void SetRenderer(vtkRenderer* renderer);
126
131
133
137 vtkPoints* inPoints, vtkPoints* outPoints, double minimumHullSize = 1.0);
139 vtkPoints* inPoints, vtkPoints* outPoints, double minimumHullSize = 1.0);
141
142protected:
145
150
151private:
152 vtkConvexHull2D(const vtkConvexHull2D&) = delete;
153 void operator=(const vtkConvexHull2D&) = delete;
154
155 void ResizeHullToMinimumInDisplay(vtkPolyData* hullPolyData);
156
157 double ScaleFactor;
158 bool Outline;
159 int HullShape;
160 int MinHullSizeInDisplay;
161 double MinHullSizeInWorld;
162 vtkRenderer* Renderer;
163
166 vtkSmartPointer<vtkTransform> OutputTransform;
168 vtkSmartPointer<vtkPolyLine> OutlineSource;
170};
171
172#endif // vtkConvexHull2D_h
Produce filled convex hulls around a set of points.
vtkRenderer * GetRenderer()
Renderer needed for MinHullSizeInDisplay calculation.
~vtkConvexHull2D() override
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
This is called by the superclass.
static void CalculateBoundingRectangle(vtkPoints *inPoints, vtkPoints *outPoints, double minimumHullSize=1.0)
Convenience methods to calculate a convex hull from a set of vtkPointS.
void SetRenderer(vtkRenderer *renderer)
Renderer needed for MinHullSizeInDisplay calculation.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
static void CalculateConvexHull(vtkPoints *inPoints, vtkPoints *outPoints, double minimumHullSize=1.0)
Convenience methods to calculate a convex hull from a set of vtkPointS.
vtkMTimeType GetMTime() override
The modified time of this filter.
static vtkConvexHull2D * New()
perform coordinate transformation, and represent position, in a variety of vtk coordinate systems
a simple class to control print indentation
Definition: vtkIndent.h:113
Store zero or more vtkInformation instances.
Store vtkAlgorithm input/output information.
represent and manipulate 3D points
Definition: vtkPoints.h:143
Superclass for algorithms that produce only polydata as output.
concrete dataset represents vertices, lines, polygons, and triangle strips
Definition: vtkPolyData.h:195
cell represents a set of 1D lines
Definition: vtkPolyLine.h:146
a cell that represents an n-sided polygon
Definition: vtkPolygon.h:149
abstract specification for renderers
Definition: vtkRenderer.h:173
transform points and associated normals and vectors for polygonal dataset
describes linear transformations via a 4x4 matrix
Definition: vtkTransform.h:164
@ Coordinate
Definition: vtkX3D.h:50
@ Transform
Definition: vtkX3D.h:47
vtkTypeUInt32 vtkMTimeType
Definition: vtkType.h:287
#define VTK_DOUBLE_MAX
Definition: vtkType.h:165
#define VTK_INT_MAX
Definition: vtkType.h:155