VTK
|
computes an interpolating spline using a Kochanek basis. More...
#include <vtkKochanekSpline.h>
Public Types | |
typedef vtkSpline | Superclass |
Public Member Functions | |
virtual int | IsA (const char *type) |
vtkKochanekSpline * | NewInstance () const |
void | PrintSelf (ostream &os, vtkIndent indent) |
void | Compute () |
double | Evaluate (double t) |
virtual void | DeepCopy (vtkSpline *s) |
virtual void | SetDefaultBias (double) |
virtual double | GetDefaultBias () |
virtual void | SetDefaultTension (double) |
virtual double | GetDefaultTension () |
virtual void | SetDefaultContinuity (double) |
virtual double | GetDefaultContinuity () |
Static Public Member Functions | |
static int | IsTypeOf (const char *type) |
static vtkKochanekSpline * | SafeDownCast (vtkObjectBase *o) |
static vtkKochanekSpline * | New () |
Protected Member Functions | |
virtual vtkObjectBase * | NewInstanceInternal () const |
vtkKochanekSpline () | |
~vtkKochanekSpline () | |
void | Fit1D (int n, double *x, double *y, double tension, double bias, double continuity, double coefficients[][4], int leftConstraint, double leftValue, int rightConstraint, double rightValue) |
Protected Attributes | |
double | DefaultBias |
double | DefaultTension |
double | DefaultContinuity |
computes an interpolating spline using a Kochanek basis.
Implements the Kochenek interpolating spline described in: Kochanek, D., Bartels, R., "Interpolating Splines with Local Tension, Continuity, and Bias Control," Computer Graphics, vol. 18, no. 3, pp. 33-41, July 1984. These splines give the user more control over the shape of the curve than the cardinal splines implemented in vtkCardinalSpline. Three parameters can be specified. All have a range from -1 to 1.
Tension controls how sharply the curve bends at an input point. A value of -1 produces more slack in the curve. A value of 1 tightens the curve.
Continuity controls the continuity of the first derivative at input points.
Bias controls the direction of the curve at it passes through an input point. A value of -1 undershoots the point while a value of 1 overshoots the point.
These three parameters give the user broad control over the shape of the interpolating spline. The original Kochanek paper describes the effects nicely and is recommended reading.
Definition at line 56 of file vtkKochanekSpline.h.
Reimplemented from vtkSpline.
Definition at line 59 of file vtkKochanekSpline.h.
vtkKochanekSpline::vtkKochanekSpline | ( | ) | [protected] |
vtkKochanekSpline::~vtkKochanekSpline | ( | ) | [inline, protected] |
Definition at line 95 of file vtkKochanekSpline.h.
static int vtkKochanekSpline::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 vtkSpline.
virtual int vtkKochanekSpline::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 vtkSpline.
static vtkKochanekSpline* vtkKochanekSpline::SafeDownCast | ( | vtkObjectBase * | o | ) | [static] |
Reimplemented from vtkSpline.
virtual vtkObjectBase* vtkKochanekSpline::NewInstanceInternal | ( | ) | const [protected, virtual] |
Reimplemented from vtkSpline.
vtkKochanekSpline* vtkKochanekSpline::NewInstance | ( | ) | const |
Reimplemented from vtkSpline.
void vtkKochanekSpline::PrintSelf | ( | ostream & | os, |
vtkIndent | indent | ||
) | [virtual] |
static vtkKochanekSpline* vtkKochanekSpline::New | ( | ) | [static] |
Construct a KochanekSpline with the following defaults: DefaultBias = 0, DefaultTension = 0, DefaultContinuity = 0.
Reimplemented from vtkObject.
void vtkKochanekSpline::Compute | ( | ) | [virtual] |
Compute Kochanek Spline coefficients.
Implements vtkSpline.
double vtkKochanekSpline::Evaluate | ( | double | t | ) | [virtual] |
Evaluate a 1D Kochanek spline.
Implements vtkSpline.
virtual void vtkKochanekSpline::SetDefaultBias | ( | double | ) | [virtual] |
Set the bias for all points. Default is 0.
virtual double vtkKochanekSpline::GetDefaultBias | ( | ) | [virtual] |
Set the bias for all points. Default is 0.
virtual void vtkKochanekSpline::SetDefaultTension | ( | double | ) | [virtual] |
Set the tension for all points. Default is 0.
virtual double vtkKochanekSpline::GetDefaultTension | ( | ) | [virtual] |
Set the tension for all points. Default is 0.
virtual void vtkKochanekSpline::SetDefaultContinuity | ( | double | ) | [virtual] |
Set the continuity for all points. Default is 0.
virtual double vtkKochanekSpline::GetDefaultContinuity | ( | ) | [virtual] |
Set the continuity for all points. Default is 0.
virtual void vtkKochanekSpline::DeepCopy | ( | vtkSpline * | s | ) | [virtual] |
Deep copy of cardinal spline data.
Reimplemented from vtkSpline.
void vtkKochanekSpline::Fit1D | ( | int | n, |
double * | x, | ||
double * | y, | ||
double | tension, | ||
double | bias, | ||
double | continuity, | ||
double | coefficients[][4], | ||
int | leftConstraint, | ||
double | leftValue, | ||
int | rightConstraint, | ||
double | rightValue | ||
) | [protected] |
double vtkKochanekSpline::DefaultBias [protected] |
Definition at line 101 of file vtkKochanekSpline.h.
double vtkKochanekSpline::DefaultTension [protected] |
Definition at line 102 of file vtkKochanekSpline.h.
double vtkKochanekSpline::DefaultContinuity [protected] |
Definition at line 103 of file vtkKochanekSpline.h.