VTK  9.1.0
vtkSplineFilter.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkSplineFilter.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=========================================================================*/
46#ifndef vtkSplineFilter_h
47#define vtkSplineFilter_h
48
49#include "vtkFiltersGeneralModule.h" // For export macro
51
52#define VTK_SUBDIVIDE_SPECIFIED 0
53#define VTK_SUBDIVIDE_LENGTH 1
54
55#define VTK_TCOORDS_OFF 0
56#define VTK_TCOORDS_FROM_NORMALIZED_LENGTH 1
57#define VTK_TCOORDS_FROM_LENGTH 2
58#define VTK_TCOORDS_FROM_SCALARS 3
59
60class vtkCellArray;
61class vtkCellData;
62class vtkFloatArray;
63class vtkPointData;
64class vtkPoints;
65class vtkSpline;
66
67class VTKFILTERSGENERAL_EXPORT vtkSplineFilter : public vtkPolyDataAlgorithm
68{
69public:
71 void PrintSelf(ostream& os, vtkIndent indent) override;
72
78
80
84 vtkSetClampMacro(MaximumNumberOfSubdivisions, int, 1, VTK_INT_MAX);
85 vtkGetMacro(MaximumNumberOfSubdivisions, int);
87
89
92 vtkSetClampMacro(Subdivide, int, VTK_SUBDIVIDE_SPECIFIED, VTK_SUBDIVIDE_LENGTH);
93 vtkGetMacro(Subdivide, int);
94 void SetSubdivideToSpecified() { this->SetSubdivide(VTK_SUBDIVIDE_SPECIFIED); }
95 void SetSubdivideToLength() { this->SetSubdivide(VTK_SUBDIVIDE_LENGTH); }
96 const char* GetSubdivideAsString();
98
100
105 vtkSetClampMacro(NumberOfSubdivisions, int, 1, VTK_INT_MAX);
106 vtkGetMacro(NumberOfSubdivisions, int);
108
110
115 vtkSetClampMacro(Length, double, 0.0000001, VTK_DOUBLE_MAX);
116 vtkGetMacro(Length, double);
118
120
123 virtual void SetSpline(vtkSpline*);
124 vtkGetObjectMacro(Spline, vtkSpline);
126
128
135 vtkSetClampMacro(GenerateTCoords, int, VTK_TCOORDS_OFF, VTK_TCOORDS_FROM_SCALARS);
136 vtkGetMacro(GenerateTCoords, int);
137 void SetGenerateTCoordsToOff() { this->SetGenerateTCoords(VTK_TCOORDS_OFF); }
139 {
140 this->SetGenerateTCoords(VTK_TCOORDS_FROM_NORMALIZED_LENGTH);
141 }
142 void SetGenerateTCoordsToUseLength() { this->SetGenerateTCoords(VTK_TCOORDS_FROM_LENGTH); }
143 void SetGenerateTCoordsToUseScalars() { this->SetGenerateTCoords(VTK_TCOORDS_FROM_SCALARS); }
146
148
154 vtkSetClampMacro(TextureLength, double, 0.000001, VTK_INT_MAX);
155 vtkGetMacro(TextureLength, double);
157
158protected:
161
162 // Usual data generation method
164
168 double Length;
174 double TextureLength; // this length is mapped to [0,1) texture space
175
176 // helper methods
178 vtkPoints* newPts, vtkPointData* pd, vtkPointData* outPD, int genTCoords,
179 vtkFloatArray* newTCoords);
180
182 vtkCellData* outCD, vtkCellArray* newLines);
183
184 // helper members
186
187private:
188 vtkSplineFilter(const vtkSplineFilter&) = delete;
189 void operator=(const vtkSplineFilter&) = delete;
190};
191
192#endif
object to represent cell connectivity
Definition: vtkCellArray.h:190
represent and manipulate cell attribute data
Definition: vtkCellData.h:42
dynamic, self-adjusting array of float
Definition: vtkFloatArray.h:45
a simple class to control print indentation
Definition: vtkIndent.h:43
Store zero or more vtkInformation instances.
Store vtkAlgorithm input/output information.
represent and manipulate point attribute data
Definition: vtkPointData.h:42
represent and manipulate 3D points
Definition: vtkPoints.h:43
Superclass for algorithms that produce only polydata as output.
generate uniformly subdivided polylines from a set of input polyline using a vtkSpline
void SetGenerateTCoordsToNormalizedLength()
Control whether and how texture coordinates are produced.
void SetGenerateTCoordsToOff()
Control whether and how texture coordinates are produced.
void SetGenerateTCoordsToUseScalars()
Control whether and how texture coordinates are produced.
vtkSpline * XSpline
vtkSpline * ZSpline
static vtkSplineFilter * New()
Construct the class with no limit on the number of subdivisions and using an instance of vtkCardinalS...
vtkSpline * Spline
void SetSubdivideToLength()
Specify how the number of subdivisions is determined.
~vtkSplineFilter() override
int GeneratePoints(vtkIdType offset, vtkIdType npts, const vtkIdType *pts, vtkPoints *inPts, vtkPoints *newPts, vtkPointData *pd, vtkPointData *outPD, int genTCoords, vtkFloatArray *newTCoords)
void GenerateLine(vtkIdType offset, vtkIdType numGenPts, vtkIdType inCellId, vtkCellData *cd, vtkCellData *outCD, vtkCellArray *newLines)
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkSpline * YSpline
virtual void SetSpline(vtkSpline *)
Specify an instance of vtkSpline to use to perform the interpolation.
vtkFloatArray * TCoordMap
const char * GetSubdivideAsString()
Specify how the number of subdivisions is determined.
const char * GetGenerateTCoordsAsString()
Control whether and how texture coordinates are produced.
void SetSubdivideToSpecified()
Specify how the number of subdivisions is determined.
void SetGenerateTCoordsToUseLength()
Control whether and how texture coordinates are produced.
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
This is called by the superclass.
spline abstract class for interpolating splines
Definition: vtkSpline.h:63
@ offset
Definition: vtkX3D.h:444
#define VTK_TCOORDS_FROM_SCALARS
#define VTK_TCOORDS_FROM_LENGTH
#define VTK_SUBDIVIDE_LENGTH
#define VTK_TCOORDS_FROM_NORMALIZED_LENGTH
#define VTK_TCOORDS_OFF
#define VTK_SUBDIVIDE_SPECIFIED
int vtkIdType
Definition: vtkType.h:332
#define VTK_DOUBLE_MAX
Definition: vtkType.h:165
#define VTK_INT_MAX
Definition: vtkType.h:155