vtkParametricFunction Class Reference
#include <vtkParametricFunction.h>
Inheritance diagram for vtkParametricFunction:
[legend]Collaboration diagram for vtkParametricFunction:
[legend]List of all members.
Detailed Description
abstract interface for parametric functions
vtkParametricFunction is an abstract interface for functions defined by parametric mapping i.e. f(u,v,w)->(x,y,z) where u_min <= u < u_max, v_min <= v < v_max, w_min <= w < w_max. (For notational convenience, we will write f(u)->x and assume that u means (u,v,w) and x means (x,y,z).)
The interface contains the pure virtual function, Evaluate(), that generates a point and the derivatives at that point which are then used to construct the surface. A second pure virtual function, EvaluateScalar(), can be used to generate a scalar for the surface. Finally, the GetDimension() virtual function is used to differentiate 1D, 2D, and 3D parametric functions. Since this abstract class defines a pure virtual API, its subclasses must implement the pure virtual functions GetDimension(), Evaluate() and EvaluateScalar().
This class has also methods for defining a range of parametric values (u,v,w).
- Thanks:
- Andrew Maclean a.maclean@cas.edu.au for creating and contributing the class.
- See also:
- vtkParametricFunctionSource - tessellates a parametric function
Implementations of derived classes implementing non-orentable surfaces: vtkParametricBoy vtkParametricCrossCap vtkParametricFigure8Klein vtkParametricKlein vtkParametricMobius vtkParametricRoman
Implementations of derived classes implementing orientable surfaces: vtkParametricConicSpiral vtkParametricDini vtkParametricEllipsoid vtkParametricEnneper vtkParametricRandomHills vtkParametricSuperEllipsoid vtkParametricSuperToroid vtkParametricTorus
Definition at line 60 of file vtkParametricFunction.h.
Member Typedef Documentation
|
Reimplemented from vtkObject.
Reimplemented in vtkParametricBoy, vtkParametricConicSpiral, vtkParametricCrossCap, vtkParametricDini, vtkParametricEllipsoid, vtkParametricEnneper, vtkParametricFigure8Klein, vtkParametricKlein, vtkParametricMobius, vtkParametricRandomHills, vtkParametricRoman, vtkParametricSuperEllipsoid, vtkParametricSuperToroid, vtkParametricTorus, and vtkParametricSpline.
Definition at line 63 of file vtkParametricFunction.h. |
Constructor & Destructor Documentation
vtkParametricFunction::vtkParametricFunction |
( |
|
) |
[protected] |
|
virtual vtkParametricFunction::~vtkParametricFunction |
( |
|
) |
[protected, virtual] |
|
Member Function Documentation
virtual const char* vtkParametricFunction::GetClassName |
( |
|
) |
[virtual] |
|
|
Reimplemented from vtkObject.
Reimplemented in vtkParametricBoy, vtkParametricConicSpiral, vtkParametricCrossCap, vtkParametricDini, vtkParametricEllipsoid, vtkParametricEnneper, vtkParametricFigure8Klein, vtkParametricKlein, vtkParametricMobius, vtkParametricRandomHills, vtkParametricRoman, vtkParametricSuperEllipsoid, vtkParametricSuperToroid, vtkParametricTorus, and vtkParametricSpline. |
static int vtkParametricFunction::IsTypeOf |
( |
const char * |
type |
) |
[static] |
|
|
Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeRevisionMacro found in vtkSetGet.h.
Reimplemented from vtkObject.
Reimplemented in vtkParametricBoy, vtkParametricConicSpiral, vtkParametricCrossCap, vtkParametricDini, vtkParametricEllipsoid, vtkParametricEnneper, vtkParametricFigure8Klein, vtkParametricKlein, vtkParametricMobius, vtkParametricRandomHills, vtkParametricRoman, vtkParametricSuperEllipsoid, vtkParametricSuperToroid, vtkParametricTorus, and vtkParametricSpline. |
virtual int vtkParametricFunction::IsA |
( |
const char * |
type |
) |
[virtual] |
|
|
Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeRevisionMacro found in vtkSetGet.h.
Reimplemented from vtkObject.
Reimplemented in vtkParametricBoy, vtkParametricConicSpiral, vtkParametricCrossCap, vtkParametricDini, vtkParametricEllipsoid, vtkParametricEnneper, vtkParametricFigure8Klein, vtkParametricKlein, vtkParametricMobius, vtkParametricRandomHills, vtkParametricRoman, vtkParametricSuperEllipsoid, vtkParametricSuperToroid, vtkParametricTorus, and vtkParametricSpline. |
|
Reimplemented from vtkObject.
Reimplemented in vtkParametricBoy, vtkParametricConicSpiral, vtkParametricCrossCap, vtkParametricDini, vtkParametricEllipsoid, vtkParametricEnneper, vtkParametricFigure8Klein, vtkParametricKlein, vtkParametricMobius, vtkParametricRandomHills, vtkParametricRoman, vtkParametricSuperEllipsoid, vtkParametricSuperToroid, vtkParametricTorus, and vtkParametricSpline. |
void vtkParametricFunction::PrintSelf |
( |
ostream & |
os, |
|
|
vtkIndent |
indent |
|
) |
[virtual] |
|
|
Methods invoked by print to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.
Reimplemented from vtkObject.
Reimplemented in vtkParametricBoy, vtkParametricConicSpiral, vtkParametricCrossCap, vtkParametricDini, vtkParametricEllipsoid, vtkParametricEnneper, vtkParametricFigure8Klein, vtkParametricKlein, vtkParametricMobius, vtkParametricRandomHills, vtkParametricRoman, vtkParametricSuperEllipsoid, vtkParametricSuperToroid, vtkParametricTorus, and vtkParametricSpline. |
virtual int vtkParametricFunction::GetDimension |
( |
|
) |
[pure virtual] |
|
|
Return the dimension of parametric space. Depending on the dimension, then the (u,v,w) parameters and associated information (e.g., derivates) have meaning. For example, if the dimension of the function is one, then u[0] and Duvw[0...2] have meaning. This is a pure virtual function that must be instantiated in a derived class.
Implemented in vtkParametricBoy, vtkParametricConicSpiral, vtkParametricCrossCap, vtkParametricDini, vtkParametricEllipsoid, vtkParametricEnneper, vtkParametricFigure8Klein, vtkParametricKlein, vtkParametricMobius, vtkParametricRandomHills, vtkParametricRoman, vtkParametricSuperEllipsoid, vtkParametricSuperToroid, vtkParametricTorus, and vtkParametricSpline. |
virtual void vtkParametricFunction::Evaluate |
( |
double |
uvw[3], |
|
|
double |
Pt[3], |
|
|
double |
Duvw[9] |
|
) |
[pure virtual] |
|
|
Performs the mapping $f(uvw)->(Pt,Duvw)$f. This is a pure virtual function that must be instantiated in a derived class. uvw are the parameters, with u corresponding to uvw[0], v to uvw[1] and w to uvw[2] respectively. Pt is the returned Cartesian point, Duvw are the derivatives of this point with respect to u, v and w. Note that the first three values in Duvw are Du, the next three are Dv, and the final three are Dw. Du Dv Dw are the partial derivatives of the function at the point Pt with respect to u, v and w respectively.
Implemented in vtkParametricBoy, vtkParametricConicSpiral, vtkParametricCrossCap, vtkParametricDini, vtkParametricEllipsoid, vtkParametricEnneper, vtkParametricFigure8Klein, vtkParametricKlein, vtkParametricMobius, vtkParametricRandomHills, vtkParametricRoman, vtkParametricSuperEllipsoid, vtkParametricSuperToroid, vtkParametricTorus, and vtkParametricSpline. |
virtual double vtkParametricFunction::EvaluateScalar |
( |
double |
uvw[3], |
|
|
double |
Pt[3], |
|
|
double |
Duvw[9] |
|
) |
[pure virtual] |
|
|
Calculate a user defined scalar using one or all of uvw, Pt, Duvw. This is a pure virtual function that must be instantiated in a derived class. uvw are the parameters with Pt being the the cartesian point, Duvw are the derivatives of this point with respect to u, v, and w. Pt, Duvw are obtained from Evaluate().
Implemented in vtkParametricBoy, vtkParametricConicSpiral, vtkParametricCrossCap, vtkParametricDini, vtkParametricEllipsoid, vtkParametricEnneper, vtkParametricFigure8Klein, vtkParametricKlein, vtkParametricMobius, vtkParametricRandomHills, vtkParametricRoman, vtkParametricSuperEllipsoid, vtkParametricSuperToroid, vtkParametricTorus, and vtkParametricSpline. |
virtual void vtkParametricFunction::SetMinimumU |
( |
double |
|
) |
[virtual] |
|
|
Set/Get the minimum u-value. |
virtual double vtkParametricFunction::GetMinimumU |
( |
|
) |
[virtual] |
|
|
Calculate a user defined scalar using one or all of uvw, Pt, Duvw. This is a pure virtual function that must be instantiated in a derived class. uvw are the parameters with Pt being the the cartesian point, Duvw are the derivatives of this point with respect to u, v, and w. Pt, Duvw are obtained from Evaluate(). |
virtual void vtkParametricFunction::SetMaximumU |
( |
double |
|
) |
[virtual] |
|
|
Set/Get the maximum u-value. |
virtual double vtkParametricFunction::GetMaximumU |
( |
|
) |
[virtual] |
|
|
Set/Get the maximum u-value. |
virtual void vtkParametricFunction::SetMinimumV |
( |
double |
|
) |
[virtual] |
|
|
Set/Get the minimum v-value. |
virtual double vtkParametricFunction::GetMinimumV |
( |
|
) |
[virtual] |
|
|
Set/Get the minimum v-value. |
virtual void vtkParametricFunction::SetMaximumV |
( |
double |
|
) |
[virtual] |
|
|
Set/Get the maximum v-value. |
virtual double vtkParametricFunction::GetMaximumV |
( |
|
) |
[virtual] |
|
|
Set/Get the maximum v-value. |
virtual void vtkParametricFunction::SetMinimumW |
( |
double |
|
) |
[virtual] |
|
|
Set/Get the minimum w-value. |
virtual double vtkParametricFunction::GetMinimumW |
( |
|
) |
[virtual] |
|
|
Set/Get the minimum w-value. |
virtual void vtkParametricFunction::SetMaximumW |
( |
double |
|
) |
[virtual] |
|
|
Set/Get the maximum w-value. |
virtual double vtkParametricFunction::GetMaximumW |
( |
|
) |
[virtual] |
|
|
Set/Get the maximum w-value. |
virtual void vtkParametricFunction::SetJoinU |
( |
int |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the first triangle strip to the last one. |
virtual int vtkParametricFunction::GetJoinU |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the first triangle strip to the last one. |
virtual void vtkParametricFunction::JoinUOn |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the first triangle strip to the last one. |
virtual void vtkParametricFunction::JoinUOff |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the first triangle strip to the last one. |
virtual void vtkParametricFunction::SetJoinV |
( |
int |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the the ends of the triangle strips. |
virtual int vtkParametricFunction::GetJoinV |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the the ends of the triangle strips. |
virtual void vtkParametricFunction::JoinVOn |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the the ends of the triangle strips. |
virtual void vtkParametricFunction::JoinVOff |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the the ends of the triangle strips. |
virtual void vtkParametricFunction::SetTwistU |
( |
int |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the first triangle strip to the last one with a twist. JoinU must also be set if this is set. Used when building some non-orientable surfaces. |
virtual int vtkParametricFunction::GetTwistU |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the first triangle strip to the last one with a twist. JoinU must also be set if this is set. Used when building some non-orientable surfaces. |
virtual void vtkParametricFunction::TwistUOn |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the first triangle strip to the last one with a twist. JoinU must also be set if this is set. Used when building some non-orientable surfaces. |
virtual void vtkParametricFunction::TwistUOff |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the first triangle strip to the last one with a twist. JoinU must also be set if this is set. Used when building some non-orientable surfaces. |
virtual void vtkParametricFunction::SetTwistV |
( |
int |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the ends of the triangle strips with a twist. JoinV must also be set if this is set. Used when building some non-orientable surfaces. |
virtual int vtkParametricFunction::GetTwistV |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the ends of the triangle strips with a twist. JoinV must also be set if this is set. Used when building some non-orientable surfaces. |
virtual void vtkParametricFunction::TwistVOn |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the ends of the triangle strips with a twist. JoinV must also be set if this is set. Used when building some non-orientable surfaces. |
virtual void vtkParametricFunction::TwistVOff |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which joins the ends of the triangle strips with a twist. JoinV must also be set if this is set. Used when building some non-orientable surfaces. |
virtual void vtkParametricFunction::SetClockwiseOrdering |
( |
int |
|
) |
[virtual] |
|
|
Set/Get the flag which determines the ordering of the the vertices forming the triangle strips. The ordering of the points being inserted into the triangle strip is important because it determines the direction of the normals for the lighting. If set, the ordering is clockwise, otherwise the ordering is anti-clockwise. Default is true (i.e. clockwise ordering). |
virtual int vtkParametricFunction::GetClockwiseOrdering |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which determines the ordering of the the vertices forming the triangle strips. The ordering of the points being inserted into the triangle strip is important because it determines the direction of the normals for the lighting. If set, the ordering is clockwise, otherwise the ordering is anti-clockwise. Default is true (i.e. clockwise ordering). |
virtual void vtkParametricFunction::ClockwiseOrderingOn |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which determines the ordering of the the vertices forming the triangle strips. The ordering of the points being inserted into the triangle strip is important because it determines the direction of the normals for the lighting. If set, the ordering is clockwise, otherwise the ordering is anti-clockwise. Default is true (i.e. clockwise ordering). |
virtual void vtkParametricFunction::ClockwiseOrderingOff |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which determines the ordering of the the vertices forming the triangle strips. The ordering of the points being inserted into the triangle strip is important because it determines the direction of the normals for the lighting. If set, the ordering is clockwise, otherwise the ordering is anti-clockwise. Default is true (i.e. clockwise ordering). |
virtual void vtkParametricFunction::SetDerivativesAvailable |
( |
int |
|
) |
[virtual] |
|
|
Set/Get the flag which determines whether derivatives are available from the parametric function (i.e., whether the Evaluate() method returns valid derivatives). |
virtual int vtkParametricFunction::GetDerivativesAvailable |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which determines whether derivatives are available from the parametric function (i.e., whether the Evaluate() method returns valid derivatives). |
virtual void vtkParametricFunction::DerivativesAvailableOn |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which determines whether derivatives are available from the parametric function (i.e., whether the Evaluate() method returns valid derivatives). |
virtual void vtkParametricFunction::DerivativesAvailableOff |
( |
|
) |
[virtual] |
|
|
Set/Get the flag which determines whether derivatives are available from the parametric function (i.e., whether the Evaluate() method returns valid derivatives). |
Member Data Documentation
The documentation for this class was generated from the following file:
Generated on Tue Jan 22 00:05:44 2008 for VTK by
1.4.3-20050530