VTK
|
create a polygonal superquadric centered at the origin More...
#include <vtkSuperquadricSource.h>
create a polygonal superquadric centered at the origin
vtkSuperquadricSource creates a superquadric (represented by polygons) of specified size centered at the origin. The alignment of the axis of the superquadric along one of the global axes can be specified. The resolution (polygonal discretization) in both the latitude (phi) and longitude (theta) directions can be specified. 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 66 of file vtkSuperquadricSource.h.
Reimplemented from vtkPolyDataAlgorithm.
Definition at line 74 of file vtkSuperquadricSource.h.
vtkSuperquadricSource::vtkSuperquadricSource | ( | int | res = 16 | ) | [protected] |
vtkSuperquadricSource::~vtkSuperquadricSource | ( | ) | [inline, protected] |
Definition at line 151 of file vtkSuperquadricSource.h.
static vtkSuperquadricSource* vtkSuperquadricSource::New | ( | ) | [static] |
Create a default superquadric with a radius of 0.5, non-toroidal, spherical, and centered at the origin, with a scaling factor of 1 in each direction, a theta resolution and a phi resolutions of 16.
Reimplemented from vtkPolyDataAlgorithm.
static int vtkSuperquadricSource::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 vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkPolyDataAlgorithm.
virtual int vtkSuperquadricSource::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 vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkPolyDataAlgorithm.
static vtkSuperquadricSource* vtkSuperquadricSource::SafeDownCast | ( | vtkObjectBase * | o | ) | [static] |
Reimplemented from vtkPolyDataAlgorithm.
virtual vtkObjectBase* vtkSuperquadricSource::NewInstanceInternal | ( | ) | const [protected, virtual] |
Reimplemented from vtkPolyDataAlgorithm.
Reimplemented from vtkPolyDataAlgorithm.
void vtkSuperquadricSource::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 vtkPolyDataAlgorithm.
virtual void vtkSuperquadricSource::SetCenter | ( | double | , |
double | , | ||
double | |||
) | [virtual] |
Set the center of the superquadric. Default is 0,0,0.
virtual void vtkSuperquadricSource::SetCenter | ( | double | [3] | ) | [virtual] |
Set the center of the superquadric. Default is 0,0,0.
virtual double* vtkSuperquadricSource::GetCenter | ( | ) | [virtual] |
Set the center of the superquadric. Default is 0,0,0.
virtual void vtkSuperquadricSource::GetCenter | ( | double | data[3] | ) | [virtual] |
Set the center of the superquadric. Default is 0,0,0.
virtual void vtkSuperquadricSource::SetScale | ( | double | , |
double | , | ||
double | |||
) | [virtual] |
Set the scale factors of the superquadric. Default is 1,1,1.
virtual void vtkSuperquadricSource::SetScale | ( | double | [3] | ) | [virtual] |
Set the scale factors of the superquadric. Default is 1,1,1.
virtual double* vtkSuperquadricSource::GetScale | ( | ) | [virtual] |
Set the scale factors of the superquadric. Default is 1,1,1.
virtual void vtkSuperquadricSource::GetScale | ( | double | data[3] | ) | [virtual] |
Set the scale factors of the superquadric. Default is 1,1,1.
virtual int vtkSuperquadricSource::GetThetaResolution | ( | ) | [virtual] |
Set the number of points in the longitude direction. Initial value is
void vtkSuperquadricSource::SetThetaResolution | ( | int | i | ) |
Set the number of points in the longitude direction. Initial value is
virtual int vtkSuperquadricSource::GetPhiResolution | ( | ) | [virtual] |
Set the number of points in the latitude direction. Initial value is
void vtkSuperquadricSource::SetPhiResolution | ( | int | i | ) |
Set the number of points in the latitude direction. Initial value is
virtual double vtkSuperquadricSource::GetThickness | ( | ) | [virtual] |
Set/Get Superquadric ring thickness (toroids only). Changing thickness maintains the outside diameter of the toroid. Initial value is 0.3333.
virtual void vtkSuperquadricSource::SetThickness | ( | double | ) | [virtual] |
Set/Get Superquadric ring thickness (toroids only). Changing thickness maintains the outside diameter of the toroid. Initial value is 0.3333.
virtual double vtkSuperquadricSource::GetPhiRoundness | ( | ) | [virtual] |
Set/Get Superquadric north/south roundness. Values range from 0 (rectangular) to 1 (circular) to higher orders. Initial value is 1.0.
void vtkSuperquadricSource::SetPhiRoundness | ( | double | e | ) |
Set/Get Superquadric north/south roundness. Values range from 0 (rectangular) to 1 (circular) to higher orders. Initial value is 1.0.
virtual double vtkSuperquadricSource::GetThetaRoundness | ( | ) | [virtual] |
Set/Get Superquadric east/west roundness. Values range from 0 (rectangular) to 1 (circular) to higher orders. Initial value is 1.0.
Set/Get Superquadric east/west roundness. Values range from 0 (rectangular) to 1 (circular) to higher orders. Initial value is 1.0.
virtual void vtkSuperquadricSource::SetSize | ( | double | ) | [virtual] |
Set/Get Superquadric isotropic size. Initial value is 0.5;
virtual double vtkSuperquadricSource::GetSize | ( | ) | [virtual] |
Set/Get Superquadric isotropic size. Initial value is 0.5;
virtual void vtkSuperquadricSource::SetAxisOfSymmetry | ( | int | ) | [virtual] |
Set/Get axis of symmetry for superquadric (x axis: 0, y axis: 1, z axis: 2). Initial value is 1.
virtual int vtkSuperquadricSource::GetAxisOfSymmetry | ( | ) | [virtual] |
Set/Get axis of symmetry for superquadric (x axis: 0, y axis: 1, z axis: 2). Initial value is 1.
void vtkSuperquadricSource::SetXAxisOfSymmetry | ( | ) | [inline] |
Set/Get axis of symmetry for superquadric (x axis: 0, y axis: 1, z axis: 2). Initial value is 1.
Definition at line 136 of file vtkSuperquadricSource.h.
void vtkSuperquadricSource::SetYAxisOfSymmetry | ( | ) | [inline] |
Set/Get axis of symmetry for superquadric (x axis: 0, y axis: 1, z axis: 2). Initial value is 1.
Definition at line 137 of file vtkSuperquadricSource.h.
void vtkSuperquadricSource::SetZAxisOfSymmetry | ( | ) | [inline] |
Set/Get axis of symmetry for superquadric (x axis: 0, y axis: 1, z axis: 2). Initial value is 1.
Definition at line 138 of file vtkSuperquadricSource.h.
virtual void vtkSuperquadricSource::ToroidalOn | ( | ) | [virtual] |
Set/Get whether or not the superquadric is toroidal (1) or ellipsoidal (0). Initial value is 0.
virtual void vtkSuperquadricSource::ToroidalOff | ( | ) | [virtual] |
Set/Get whether or not the superquadric is toroidal (1) or ellipsoidal (0). Initial value is 0.
virtual int vtkSuperquadricSource::GetToroidal | ( | ) | [virtual] |
Set/Get whether or not the superquadric is toroidal (1) or ellipsoidal (0). Initial value is 0.
virtual void vtkSuperquadricSource::SetToroidal | ( | int | ) | [virtual] |
Set/Get whether or not the superquadric is toroidal (1) or ellipsoidal (0). Initial value is 0.
int vtkSuperquadricSource::RequestData | ( | vtkInformation * | request, |
vtkInformationVector ** | inputVector, | ||
vtkInformationVector * | outputVector | ||
) | [protected, virtual] |
This is called by the superclass. This is the method you should override.
Reimplemented from vtkPolyDataAlgorithm.
int vtkSuperquadricSource::Toroidal [protected] |
Definition at line 151 of file vtkSuperquadricSource.h.
int vtkSuperquadricSource::AxisOfSymmetry [protected] |
Definition at line 154 of file vtkSuperquadricSource.h.
double vtkSuperquadricSource::Thickness [protected] |
Definition at line 155 of file vtkSuperquadricSource.h.
double vtkSuperquadricSource::Size [protected] |
Definition at line 156 of file vtkSuperquadricSource.h.
double vtkSuperquadricSource::PhiRoundness [protected] |
Definition at line 157 of file vtkSuperquadricSource.h.
double vtkSuperquadricSource::ThetaRoundness [protected] |
Definition at line 158 of file vtkSuperquadricSource.h.
double vtkSuperquadricSource::Center[3] [protected] |
Definition at line 160 of file vtkSuperquadricSource.h.
double vtkSuperquadricSource::Scale[3] [protected] |
Definition at line 161 of file vtkSuperquadricSource.h.
int vtkSuperquadricSource::ThetaResolution [protected] |
Definition at line 162 of file vtkSuperquadricSource.h.
int vtkSuperquadricSource::PhiResolution [protected] |
Definition at line 163 of file vtkSuperquadricSource.h.