VTK
vtkParametricFunction.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkParametricFunction.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 =========================================================================*/
55 #ifndef __vtkParametricFunction_h
56 #define __vtkParametricFunction_h
57 
58 #include "vtkObject.h"
59 
61 {
62 public:
64  void PrintSelf(ostream& os, vtkIndent indent);
65 
71  virtual int GetDimension() = 0;
72 
81  virtual void Evaluate(double uvw[3], double Pt[3], double Duvw[9]) = 0;
82 
88  virtual double EvaluateScalar(double uvw[3], double Pt[3], double Duvw[9]) = 0;
89 
91 
92  vtkSetMacro(MinimumU,double);
93  vtkGetMacro(MinimumU,double);
95 
97 
98  vtkSetMacro(MaximumU,double);
99  vtkGetMacro(MaximumU,double);
101 
103 
104  vtkSetMacro(MinimumV,double);
105  vtkGetMacro(MinimumV,double);
107 
109 
110  vtkSetMacro(MaximumV,double);
111  vtkGetMacro(MaximumV,double);
113 
115 
116  vtkSetMacro(MinimumW,double);
117  vtkGetMacro(MinimumW,double);
119 
121 
122  vtkSetMacro(MaximumW,double);
123  vtkGetMacro(MaximumW,double);
125 
127 
129  vtkSetMacro(JoinU,int);
130  vtkGetMacro(JoinU,int);
131  vtkBooleanMacro(JoinU,int);
133 
135 
136  vtkSetMacro(JoinV,int);
137  vtkGetMacro(JoinV,int);
138  vtkBooleanMacro(JoinV,int);
140 
142 
145  vtkSetMacro(TwistU,int);
146  vtkGetMacro(TwistU,int);
147  vtkBooleanMacro(TwistU,int);
149 
151 
154  vtkSetMacro(TwistV,int);
155  vtkGetMacro(TwistV,int);
156  vtkBooleanMacro(TwistV,int);
158 
160 
166  vtkSetMacro(ClockwiseOrdering,int);
167  vtkGetMacro(ClockwiseOrdering,int);
168  vtkBooleanMacro(ClockwiseOrdering,int);
170 
172 
175  vtkSetMacro(DerivativesAvailable,int);
176  vtkGetMacro(DerivativesAvailable,int);
177  vtkBooleanMacro(DerivativesAvailable,int);
179 
180 protected:
182  virtual ~vtkParametricFunction();
183 
184  // Variables
185  double MinimumU;
186  double MaximumU;
187  double MinimumV;
188  double MaximumV;
189  double MinimumW;
190  double MaximumW;
191 
192  int JoinU;
193  int JoinV;
194  int JoinW;
195 
196  int TwistU;
197  int TwistV;
198  int TwistW;
199 
201 
203 
204 private:
205  vtkParametricFunction(const vtkParametricFunction&); // Not implemented.
206  void operator=(const vtkParametricFunction&); // Not implemented.
207 
208 };
209 
210 #endif
abstract base class for most VTK objects
Definition: vtkObject.h:60
abstract interface for parametric functions
virtual void PrintSelf(ostream &os, vtkIndent indent)
a simple class to control print indentation
Definition: vtkIndent.h:37
#define VTK_COMMON_EXPORT