#include <vtkSuperquadric.h>
vtkSuperquadric computes the implicit function and function gradient for a superquadric. vtkSuperquadric is a concrete implementation of vtkImplicitFunction. The superquadric is centered at Center and axes of rotation is along the y-axis. (Use the superclass' vtkImplicitFunction transformation matrix if necessary to reposition.) Roundness parameters (PhiRoundness and ThetaRoundness) control the shape of the superquadric. The Toroidal boolean controls whether a toroidal superquadric is produced. If so, the Thickness parameter controls the thickness of the toroid: 0 is the thinnest allowable toroid, and 1 has a minimum sized hole. The Scale parameters allow the superquadric to be scaled in x, y, and z (normal vectors are correctly generated in any case). The Size parameter controls size of the superquadric.
This code is based on "Rigid physically based superquadrics", A. H. Barr, in "Graphics Gems III", David Kirk, ed., Academic Press, 1992.
Definition at line 48 of file vtkSuperquadric.h.
Public Types | |
typedef vtkImplicitFunction | Superclass |
Public Member Functions | |
virtual const char * | GetClassName () |
virtual int | IsA (const char *type) |
void | PrintSelf (ostream &os, vtkIndent indent) |
double | EvaluateFunction (double x[3]) |
double | EvaluateFunction (double x, double y, double z) |
void | EvaluateGradient (double x[3], double g[3]) |
virtual void | SetCenter (double, double, double) |
virtual void | SetCenter (double[3]) |
virtual double * | GetCenter () |
virtual void | GetCenter (double data[3]) |
virtual void | SetScale (double, double, double) |
virtual void | SetScale (double[3]) |
virtual double * | GetScale () |
virtual void | GetScale (double data[3]) |
virtual double | GetThickness () |
virtual void | SetThickness (double) |
virtual double | GetPhiRoundness () |
void | SetPhiRoundness (double e) |
virtual double | GetThetaRoundness () |
void | SetThetaRoundness (double e) |
virtual void | SetSize (double) |
virtual double | GetSize () |
virtual void | ToroidalOn () |
virtual void | ToroidalOff () |
virtual int | GetToroidal () |
virtual void | SetToroidal (int) |
Static Public Member Functions | |
static vtkSuperquadric * | New () |
static int | IsTypeOf (const char *type) |
static vtkSuperquadric * | SafeDownCast (vtkObject *o) |
Protected Member Functions | |
vtkSuperquadric () | |
~vtkSuperquadric () | |
Protected Attributes | |
int | Toroidal |
double | Thickness |
double | Size |
double | PhiRoundness |
double | ThetaRoundness |
double | Center [3] |
double | Scale [3] |
vtkSuperquadric::vtkSuperquadric | ( | ) | [protected] |
vtkSuperquadric::~vtkSuperquadric | ( | ) | [inline, protected] |
Definition at line 114 of file vtkSuperquadric.h.
static vtkSuperquadric* vtkSuperquadric::New | ( | ) | [static] |
Construct with superquadric radius of 0.5, toroidal off, center at 0.0, scale (1,1,1), size 0.5, phi roundness 1.0, and theta roundness 0.0.
Reimplemented from vtkObject.
virtual const char* vtkSuperquadric::GetClassName | ( | ) | [virtual] |
Reimplemented from vtkImplicitFunction.
static int vtkSuperquadric::IsTypeOf | ( | const char * | name | ) | [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 vtkImplicitFunction.
virtual int vtkSuperquadric::IsA | ( | const char * | name | ) | [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 vtkImplicitFunction.
static vtkSuperquadric* vtkSuperquadric::SafeDownCast | ( | vtkObject * | o | ) | [static] |
Reimplemented from vtkImplicitFunction.
void vtkSuperquadric::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 vtkImplicitFunction.
double vtkSuperquadric::EvaluateFunction | ( | double | x[3] | ) | [virtual] |
Evaluate function at position x-y-z and return value. You should generally not call this method directly, you should use FunctionValue() instead. This method must be implemented by any derived class.
Implements vtkImplicitFunction.
double vtkSuperquadric::EvaluateFunction | ( | double | x, | |
double | y, | |||
double | z | |||
) | [inline] |
Evaluate function at position x-y-z and return value. You should generally not call this method directly, you should use FunctionValue() instead. This method must be implemented by any derived class.
Reimplemented from vtkImplicitFunction.
Definition at line 61 of file vtkSuperquadric.h.
void vtkSuperquadric::EvaluateGradient | ( | double | x[3], | |
double | g[3] | |||
) | [virtual] |
Evaluate function gradient at position x-y-z and pass back vector. You should generally not call this method directly, you should use FunctionGradient() instead. This method must be implemented by any derived class.
Implements vtkImplicitFunction.
virtual void vtkSuperquadric::SetCenter | ( | double | , | |
double | , | |||
double | ||||
) | [virtual] |
Set the center of the superquadric. Default is 0,0,0.
virtual void vtkSuperquadric::SetCenter | ( | double | [3] | ) | [virtual] |
Set the center of the superquadric. Default is 0,0,0.
virtual double* vtkSuperquadric::GetCenter | ( | ) | [virtual] |
Set the center of the superquadric. Default is 0,0,0.
virtual void vtkSuperquadric::GetCenter | ( | double | data[3] | ) | [virtual] |
Set the center of the superquadric. Default is 0,0,0.
virtual void vtkSuperquadric::SetScale | ( | double | , | |
double | , | |||
double | ||||
) | [virtual] |
Set the scale factors of the superquadric. Default is 1,1,1.
virtual void vtkSuperquadric::SetScale | ( | double | [3] | ) | [virtual] |
Set the scale factors of the superquadric. Default is 1,1,1.
virtual double* vtkSuperquadric::GetScale | ( | ) | [virtual] |
Set the scale factors of the superquadric. Default is 1,1,1.
virtual void vtkSuperquadric::GetScale | ( | double | data[3] | ) | [virtual] |
Set the scale factors of the superquadric. Default is 1,1,1.
virtual double vtkSuperquadric::GetThickness | ( | ) | [virtual] |
Set/Get Superquadric ring thickness (toroids only). Changing thickness maintains the outside diameter of the toroid.
virtual void vtkSuperquadric::SetThickness | ( | double | ) | [virtual] |
Set/Get Superquadric ring thickness (toroids only). Changing thickness maintains the outside diameter of the toroid.
virtual double vtkSuperquadric::GetPhiRoundness | ( | ) | [virtual] |
Set/Get Superquadric north/south roundness. Values range from 0 (rectangular) to 1 (circular) to higher orders.
void vtkSuperquadric::SetPhiRoundness | ( | double | e | ) |
Set/Get Superquadric north/south roundness. Values range from 0 (rectangular) to 1 (circular) to higher orders.
virtual double vtkSuperquadric::GetThetaRoundness | ( | ) | [virtual] |
Set/Get Superquadric east/west roundness. Values range from 0 (rectangular) to 1 (circular) to higher orders.
void vtkSuperquadric::SetThetaRoundness | ( | double | e | ) |
Set/Get Superquadric east/west roundness. Values range from 0 (rectangular) to 1 (circular) to higher orders.
virtual void vtkSuperquadric::SetSize | ( | double | ) | [virtual] |
Set/Get Superquadric isotropic size.
virtual double vtkSuperquadric::GetSize | ( | ) | [virtual] |
Set/Get Superquadric isotropic size.
virtual void vtkSuperquadric::ToroidalOn | ( | ) | [virtual] |
Set/Get whether or not the superquadric is toroidal (1) or ellipsoidal (0).
virtual void vtkSuperquadric::ToroidalOff | ( | ) | [virtual] |
Set/Get whether or not the superquadric is toroidal (1) or ellipsoidal (0).
virtual int vtkSuperquadric::GetToroidal | ( | ) | [virtual] |
Set/Get whether or not the superquadric is toroidal (1) or ellipsoidal (0).
virtual void vtkSuperquadric::SetToroidal | ( | int | ) | [virtual] |
Set/Get whether or not the superquadric is toroidal (1) or ellipsoidal (0).
int vtkSuperquadric::Toroidal [protected] |
Definition at line 114 of file vtkSuperquadric.h.
double vtkSuperquadric::Thickness [protected] |
Definition at line 117 of file vtkSuperquadric.h.
double vtkSuperquadric::Size [protected] |
Definition at line 118 of file vtkSuperquadric.h.
double vtkSuperquadric::PhiRoundness [protected] |
Definition at line 119 of file vtkSuperquadric.h.
double vtkSuperquadric::ThetaRoundness [protected] |
Definition at line 120 of file vtkSuperquadric.h.
double vtkSuperquadric::Center[3] [protected] |
Definition at line 121 of file vtkSuperquadric.h.
double vtkSuperquadric::Scale[3] [protected] |
Definition at line 122 of file vtkSuperquadric.h.