VTK
vtkRibbonFilter.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkRibbonFilter.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 =========================================================================*/
41 #ifndef vtkRibbonFilter_h
42 #define vtkRibbonFilter_h
43 
44 #include "vtkFiltersModelingModule.h" // For export macro
45 #include "vtkPolyDataAlgorithm.h"
46 
47 #define VTK_TCOORDS_OFF 0
48 #define VTK_TCOORDS_FROM_NORMALIZED_LENGTH 1
49 #define VTK_TCOORDS_FROM_LENGTH 2
50 #define VTK_TCOORDS_FROM_SCALARS 3
51 
52 class vtkCellArray;
53 class vtkCellData;
54 class vtkDataArray;
55 class vtkFloatArray;
56 class vtkPointData;
57 class vtkPoints;
58 
60 {
61 public:
63  void PrintSelf(ostream& os, vtkIndent indent);
64 
67  static vtkRibbonFilter *New();
68 
70 
72  vtkSetClampMacro(Width,double,0,VTK_DOUBLE_MAX);
73  vtkGetMacro(Width,double);
75 
77 
79  vtkSetClampMacro(Angle,double,0,360);
80  vtkGetMacro(Angle,double);
82 
84 
86  vtkSetMacro(VaryWidth,int);
87  vtkGetMacro(VaryWidth,int);
88  vtkBooleanMacro(VaryWidth,int);
90 
92 
94  vtkSetMacro(WidthFactor,double);
95  vtkGetMacro(WidthFactor,double);
97 
99 
101  vtkSetVector3Macro(DefaultNormal,double);
102  vtkGetVectorMacro(DefaultNormal,double,3);
104 
106 
108  vtkSetMacro(UseDefaultNormal,int);
109  vtkGetMacro(UseDefaultNormal,int);
110  vtkBooleanMacro(UseDefaultNormal,int);
112 
114 
116  vtkSetClampMacro(GenerateTCoords,int,VTK_TCOORDS_OFF,
118  vtkGetMacro(GenerateTCoords,int);
120  {this->SetGenerateTCoords(VTK_TCOORDS_OFF);}
122  {this->SetGenerateTCoords(VTK_TCOORDS_FROM_NORMALIZED_LENGTH);}
124  {this->SetGenerateTCoords(VTK_TCOORDS_FROM_LENGTH);}
126  {this->SetGenerateTCoords(VTK_TCOORDS_FROM_SCALARS);}
127  const char *GetGenerateTCoordsAsString();
129 
131 
135  vtkSetClampMacro(TextureLength,double,0.000001,VTK_INT_MAX);
136  vtkGetMacro(TextureLength,double);
138 
139 protected:
140  vtkRibbonFilter();
141  ~vtkRibbonFilter();
142 
144  double Width;
145  double Angle;
146  int VaryWidth; //controls whether width varies with scalar data
147  double WidthFactor;
148  double DefaultNormal[3];
150  int GenerateTCoords; //control texture coordinate generation
151  double TextureLength; //this length is mapped to [0,1) texture space
152 
153  // Helper methods
154  int GeneratePoints(vtkIdType offset, vtkIdType npts, vtkIdType *pts,
155  vtkPoints *inPts, vtkPoints *newPts,
156  vtkPointData *pd, vtkPointData *outPD,
157  vtkFloatArray *newNormals, vtkDataArray *inScalars,
158  double range[2], vtkDataArray *inNormals);
159  void GenerateStrip(vtkIdType offset, vtkIdType npts, vtkIdType *pts,
160  vtkIdType inCellId, vtkCellData *cd, vtkCellData *outCD,
161  vtkCellArray *newStrips);
162  void GenerateTextureCoords(vtkIdType offset, vtkIdType npts, vtkIdType *pts,
163  vtkPoints *inPts, vtkDataArray *inScalars,
164  vtkFloatArray *newTCoords);
165  vtkIdType ComputeOffset(vtkIdType offset,vtkIdType npts);
166 
167  // Helper data members
168  double Theta;
169 
170 private:
171  vtkRibbonFilter(const vtkRibbonFilter&); // Not implemented.
172  void operator=(const vtkRibbonFilter&); // Not implemented.
173 };
174 
175 #endif
#define VTK_TCOORDS_OFF
void SetGenerateTCoordsToOff()
#define VTK_TCOORDS_FROM_NORMALIZED_LENGTH
represent and manipulate point attribute data
Definition: vtkPointData.h:36
create oriented ribbons from lines defined in polygonal dataset
#define VTK_DOUBLE_MAX
Definition: vtkType.h:142
Store vtkAlgorithm input/output information.
virtual int RequestData(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector)
#define VTK_INT_MAX
Definition: vtkType.h:132
represent and manipulate cell attribute data
Definition: vtkCellData.h:37
#define VTKFILTERSMODELING_EXPORT
dynamic, self-adjusting array of float
Definition: vtkFloatArray.h:45
int vtkIdType
Definition: vtkType.h:275
void SetGenerateTCoordsToUseLength()
static vtkPolyDataAlgorithm * New()
void PrintSelf(ostream &os, vtkIndent indent)
Superclass for algorithms that produce only polydata as output.
a simple class to control print indentation
Definition: vtkIndent.h:38
void SetGenerateTCoordsToUseScalars()
abstract superclass for arrays of numeric data
Definition: vtkDataArray.h:54
object to represent cell connectivity
Definition: vtkCellArray.h:49
void SetGenerateTCoordsToNormalizedLength()
#define VTK_TCOORDS_FROM_LENGTH
#define VTK_TCOORDS_FROM_SCALARS
Store zero or more vtkInformation instances.
represent and manipulate 3D points
Definition: vtkPoints.h:38