VTK
9.1.0
|
3D widget for manipulating a spline More...
#include <vtkSplineWidget.h>
Public Types | |
typedef vtk3DWidget | Superclass |
Public Types inherited from vtk3DWidget | |
typedef vtkInteractorObserver | Superclass |
Public Types inherited from vtkInteractorObserver | |
typedef vtkObject | Superclass |
Public Member Functions | |
virtual vtkTypeBool | IsA (const char *type) |
Return 1 if this class is the same type of (or a subclass of) the named class. | |
vtkSplineWidget * | NewInstance () const |
void | PrintSelf (ostream &os, vtkIndent indent) override |
Methods invoked by print to print information about the object including superclasses. | |
void | SetPlaneSource (vtkPlaneSource *plane) |
Set up a reference to a vtkPlaneSource that could be from another widget object, e.g. | |
virtual void | SetProjectionNormal (int) |
virtual int | GetProjectionNormal () |
void | SetProjectionNormalToXAxes () |
void | SetProjectionNormalToYAxes () |
void | SetProjectionNormalToZAxes () |
void | SetProjectionNormalToOblique () |
void | GetPolyData (vtkPolyData *pd) |
Grab the polydata (including points) that defines the spline. | |
int | IsClosed () |
Convenience method to determine whether the spline is closed in a geometric sense. | |
double | GetSummedLength () |
Get the approximate vs. | |
void | InitializeHandles (vtkPoints *points) |
Convenience method to allocate and set the handles from a vtkPoints instance. | |
void | SetEnabled (int) override |
Methods that satisfy the superclass' API. | |
void | PlaceWidget (double bounds[6]) override |
Methods that satisfy the superclass' API. | |
void | PlaceWidget () override |
Methods that satisfy the superclass' API. | |
void | PlaceWidget (double xmin, double xmax, double ymin, double ymax, double zmin, double zmax) override |
Methods that satisfy the superclass' API. | |
virtual void | SetProjectToPlane (vtkTypeBool) |
Force the spline widget to be projected onto one of the orthogonal planes. | |
virtual vtkTypeBool | GetProjectToPlane () |
Force the spline widget to be projected onto one of the orthogonal planes. | |
virtual void | ProjectToPlaneOn () |
Force the spline widget to be projected onto one of the orthogonal planes. | |
virtual void | ProjectToPlaneOff () |
Force the spline widget to be projected onto one of the orthogonal planes. | |
void | SetProjectionPosition (double position) |
Set the position of spline handles and points in terms of a plane's position. | |
virtual double | GetProjectionPosition () |
Set the position of spline handles and points in terms of a plane's position. | |
virtual void | SetHandleProperty (vtkProperty *) |
Set/Get the handle properties (the spheres are the handles). | |
virtual vtkProperty * | GetHandleProperty () |
Set/Get the handle properties (the spheres are the handles). | |
virtual void | SetSelectedHandleProperty (vtkProperty *) |
Set/Get the handle properties (the spheres are the handles). | |
virtual vtkProperty * | GetSelectedHandleProperty () |
Set/Get the handle properties (the spheres are the handles). | |
virtual void | SetLineProperty (vtkProperty *) |
Set/Get the line properties. | |
virtual vtkProperty * | GetLineProperty () |
Set/Get the line properties. | |
virtual void | SetSelectedLineProperty (vtkProperty *) |
Set/Get the line properties. | |
virtual vtkProperty * | GetSelectedLineProperty () |
Set/Get the line properties. | |
virtual void | SetNumberOfHandles (int npts) |
Set/Get the number of handles for this widget. | |
virtual int | GetNumberOfHandles () |
Set/Get the number of handles for this widget. | |
void | SetResolution (int resolution) |
Set/Get the number of line segments representing the spline for this widget. | |
virtual int | GetResolution () |
Set/Get the number of line segments representing the spline for this widget. | |
virtual void | SetParametricSpline (vtkParametricSpline *) |
Set the parametric spline object. | |
virtual vtkParametricSpline * | GetParametricSpline () |
Set the parametric spline object. | |
void | SetHandlePosition (int handle, double x, double y, double z) |
Set/Get the position of the spline handles. | |
void | SetHandlePosition (int handle, double xyz[3]) |
Set/Get the position of the spline handles. | |
void | GetHandlePosition (int handle, double xyz[3]) |
Set/Get the position of the spline handles. | |
double * | GetHandlePosition (int handle) |
Set/Get the position of the spline handles. | |
void | SetClosed (vtkTypeBool closed) |
Control whether the spline is open or closed. | |
virtual vtkTypeBool | GetClosed () |
Control whether the spline is open or closed. | |
virtual void | ClosedOn () |
Control whether the spline is open or closed. | |
virtual void | ClosedOff () |
Control whether the spline is open or closed. | |
virtual void | SetProcessEvents (vtkTypeBool) |
Turn on / off event processing for this widget. | |
virtual vtkTypeBool | GetProcessEvents () |
Turn on / off event processing for this widget. | |
virtual void | ProcessEventsOn () |
Turn on / off event processing for this widget. | |
virtual void | ProcessEventsOff () |
Turn on / off event processing for this widget. | |
Public Member Functions inherited from vtk3DWidget | |
virtual vtkTypeBool | IsA (const char *type) |
Return 1 if this class is the same type of (or a subclass of) the named class. | |
vtk3DWidget * | NewInstance () const |
void | PrintSelf (ostream &os, vtkIndent indent) override |
Methods invoked by print to print information about the object including superclasses. | |
virtual void | SetProp3D (vtkProp3D *) |
Specify a vtkProp3D around which to place the widget. | |
virtual vtkProp3D * | GetProp3D () |
Specify a vtkProp3D around which to place the widget. | |
virtual void | SetInputData (vtkDataSet *) |
Specify the input dataset. | |
virtual void | SetInputConnection (vtkAlgorithmOutput *) |
Specify the input dataset. | |
virtual vtkDataSet * | GetInput () |
Specify the input dataset. | |
virtual void | SetPlaceFactor (double) |
Set/Get a factor representing the scaling of the widget upon placement (via the PlaceWidget() method). | |
virtual double | GetPlaceFactor () |
Set/Get a factor representing the scaling of the widget upon placement (via the PlaceWidget() method). | |
virtual void | SetHandleSize (double) |
Set/Get the factor that controls the size of the handles that appear as part of the widget. | |
virtual double | GetHandleSize () |
Set/Get the factor that controls the size of the handles that appear as part of the widget. | |
Public Member Functions inherited from vtkInteractorObserver | |
virtual vtkTypeBool | IsA (const char *type) |
Return 1 if this class is the same type of (or a subclass of) the named class. | |
vtkInteractorObserver * | NewInstance () const |
void | PrintSelf (ostream &os, vtkIndent indent) override |
Methods invoked by print to print information about the object including superclasses. | |
virtual void | SetEnabled (int) |
Methods for turning the interactor observer on and off, and determining its state. | |
int | GetEnabled () |
void | EnabledOn () |
void | EnabledOff () |
void | On () |
void | Off () |
virtual void | OnChar () |
Sets up the keypress-i event. | |
virtual void | SetInteractor (vtkRenderWindowInteractor *iren) |
This method is used to associate the widget with the render window interactor. | |
virtual vtkRenderWindowInteractor * | GetInteractor () |
This method is used to associate the widget with the render window interactor. | |
virtual void | SetPriority (float) |
Set/Get the priority at which events are processed. | |
virtual float | GetPriority () |
Set/Get the priority at which events are processed. | |
virtual void | PickingManagedOn () |
Enable/Disable the use of a manager to process the picking. | |
virtual void | PickingManagedOff () |
Enable/Disable the use of a manager to process the picking. | |
virtual void | SetPickingManaged (bool managed) |
Enable/Disable the use of a manager to process the picking. | |
virtual bool | GetPickingManaged () |
Enable/Disable the use of a manager to process the picking. | |
virtual void | SetKeyPressActivation (vtkTypeBool) |
Enable/Disable of the use of a keypress to turn on and off the interactor observer. | |
virtual vtkTypeBool | GetKeyPressActivation () |
Enable/Disable of the use of a keypress to turn on and off the interactor observer. | |
virtual void | KeyPressActivationOn () |
Enable/Disable of the use of a keypress to turn on and off the interactor observer. | |
virtual void | KeyPressActivationOff () |
Enable/Disable of the use of a keypress to turn on and off the interactor observer. | |
virtual void | SetKeyPressActivationValue (char) |
Specify which key press value to use to activate the interactor observer (if key press activation is enabled). | |
virtual char | GetKeyPressActivationValue () |
Specify which key press value to use to activate the interactor observer (if key press activation is enabled). | |
virtual vtkRenderer * | GetDefaultRenderer () |
Set/Get the default renderer to use when activating the interactor observer. | |
virtual void | SetDefaultRenderer (vtkRenderer *) |
Set/Get the default renderer to use when activating the interactor observer. | |
virtual vtkRenderer * | GetCurrentRenderer () |
Set/Get the current renderer. | |
virtual void | SetCurrentRenderer (vtkRenderer *) |
Set/Get the current renderer. | |
void | GrabFocus (vtkCommand *mouseEvents, vtkCommand *keypressEvents=nullptr) |
These methods enable an interactor observer to exclusively grab all events invoked by its associated vtkRenderWindowInteractor. | |
void | ReleaseFocus () |
These methods enable an interactor observer to exclusively grab all events invoked by its associated vtkRenderWindowInteractor. | |
Public Member Functions inherited from vtkObject | |
vtkBaseTypeMacro (vtkObject, vtkObjectBase) | |
virtual void | DebugOn () |
Turn debugging output on. | |
virtual void | DebugOff () |
Turn debugging output off. | |
bool | GetDebug () |
Get the value of the debug flag. | |
void | SetDebug (bool debugFlag) |
Set the value of the debug flag. | |
virtual void | Modified () |
Update the modification time for this object. | |
virtual vtkMTimeType | GetMTime () |
Return this object's modified time. | |
void | PrintSelf (ostream &os, vtkIndent indent) override |
Methods invoked by print to print information about the object including superclasses. | |
void | RemoveObserver (unsigned long tag) |
void | RemoveObservers (unsigned long event) |
void | RemoveObservers (const char *event) |
void | RemoveAllObservers () |
vtkTypeBool | HasObserver (unsigned long event) |
vtkTypeBool | HasObserver (const char *event) |
int | InvokeEvent (unsigned long event) |
int | InvokeEvent (const char *event) |
unsigned long | AddObserver (unsigned long event, vtkCommand *, float priority=0.0f) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. | |
unsigned long | AddObserver (const char *event, vtkCommand *, float priority=0.0f) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. | |
vtkCommand * | GetCommand (unsigned long tag) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. | |
void | RemoveObserver (vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. | |
void | RemoveObservers (unsigned long event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. | |
void | RemoveObservers (const char *event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. | |
vtkTypeBool | HasObserver (unsigned long event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. | |
vtkTypeBool | HasObserver (const char *event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. | |
template<class U , class T > | |
unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(), float priority=0.0f) |
Overloads to AddObserver that allow developers to add class member functions as callbacks for events. | |
template<class U , class T > | |
unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) |
Overloads to AddObserver that allow developers to add class member functions as callbacks for events. | |
template<class U , class T > | |
unsigned long | AddObserver (unsigned long event, U observer, bool(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) |
Allow user to set the AbortFlagOn() with the return value of the callback method. | |
int | InvokeEvent (unsigned long event, void *callData) |
This method invokes an event and return whether the event was aborted or not. | |
int | InvokeEvent (const char *event, void *callData) |
This method invokes an event and return whether the event was aborted or not. | |
Public Member Functions inherited from vtkObjectBase | |
const char * | GetClassName () const |
Return the class name as a string. | |
virtual vtkTypeBool | IsA (const char *name) |
Return 1 if this class is the same type of (or a subclass of) the named class. | |
virtual vtkIdType | GetNumberOfGenerationsFromBase (const char *name) |
Given the name of a base class of this class type, return the distance of inheritance between this class type and the named class (how many generations of inheritance are there between this class and the named class). | |
virtual void | Delete () |
Delete a VTK object. | |
virtual void | FastDelete () |
Delete a reference to this object. | |
void | InitializeObjectBase () |
void | Print (ostream &os) |
Print an object to an ostream. | |
virtual void | Register (vtkObjectBase *o) |
Increase the reference count (mark as used by another object). | |
virtual void | UnRegister (vtkObjectBase *o) |
Decrease the reference count (release by another object). | |
int | GetReferenceCount () |
Return the current reference count of this object. | |
void | SetReferenceCount (int) |
Sets the reference count. | |
bool | GetIsInMemkind () const |
A local state flag that remembers whether this object lives in the normal or extended memory space. | |
virtual void | PrintHeader (ostream &os, vtkIndent indent) |
Methods invoked by print to print information about the object including superclasses. | |
virtual void | PrintTrailer (ostream &os, vtkIndent indent) |
Methods invoked by print to print information about the object including superclasses. | |
Static Public Member Functions | |
static vtkSplineWidget * | New () |
Instantiate the object. | |
static vtkTypeBool | IsTypeOf (const char *type) |
static vtkSplineWidget * | SafeDownCast (vtkObjectBase *o) |
Static Public Member Functions inherited from vtk3DWidget | |
static vtkTypeBool | IsTypeOf (const char *type) |
static vtk3DWidget * | SafeDownCast (vtkObjectBase *o) |
Static Public Member Functions inherited from vtkInteractorObserver | |
static vtkTypeBool | IsTypeOf (const char *type) |
static vtkInteractorObserver * | SafeDownCast (vtkObjectBase *o) |
static void | ComputeDisplayToWorld (vtkRenderer *ren, double x, double y, double z, double worldPt[4]) |
Convenience methods for outside classes. | |
static void | ComputeWorldToDisplay (vtkRenderer *ren, double x, double y, double z, double displayPt[3]) |
Convenience methods for outside classes. | |
Static Public Member Functions inherited from vtkObject | |
static vtkObject * | New () |
Create an object with Debug turned off, modified time initialized to zero, and reference counting on. | |
static void | BreakOnError () |
This method is called when vtkErrorMacro executes. | |
static void | SetGlobalWarningDisplay (int val) |
This is a global flag that controls whether any debug, warning or error messages are displayed. | |
static void | GlobalWarningDisplayOn () |
This is a global flag that controls whether any debug, warning or error messages are displayed. | |
static void | GlobalWarningDisplayOff () |
This is a global flag that controls whether any debug, warning or error messages are displayed. | |
static int | GetGlobalWarningDisplay () |
This is a global flag that controls whether any debug, warning or error messages are displayed. | |
Static Public Member Functions inherited from vtkObjectBase | |
static vtkTypeBool | IsTypeOf (const char *name) |
Return 1 if this class type is the same type of (or a subclass of) the named class. | |
static vtkIdType | GetNumberOfGenerationsFromBaseType (const char *name) |
Given a the name of a base class of this class type, return the distance of inheritance between this class type and the named class (how many generations of inheritance are there between this class and the named class). | |
static vtkObjectBase * | New () |
Create an object with Debug turned off, modified time initialized to zero, and reference counting on. | |
static void | SetMemkindDirectory (const char *directoryname) |
The name of a directory, ideally mounted -o dax, to memory map an extended memory space within. | |
static bool | GetUsingMemkind () |
A global state flag that controls whether vtkObjects are constructed in the usual way (the default) or within the extended memory space. | |
Protected Types | |
enum | WidgetState { Start = 0 , Moving , Scaling , Spinning , Inserting , Erasing , Outside } |
Protected Member Functions | |
virtual vtkObjectBase * | NewInstanceInternal () const |
vtkSplineWidget () | |
~vtkSplineWidget () override | |
void | OnLeftButtonDown () |
void | OnLeftButtonUp () |
void | OnMiddleButtonDown () |
void | OnMiddleButtonUp () |
void | OnRightButtonDown () |
void | OnRightButtonUp () |
void | OnMouseMove () |
void | ProjectPointsToPlane () |
void | ProjectPointsToOrthoPlane () |
void | ProjectPointsToObliquePlane () |
void | BuildRepresentation () |
void | HighlightLine (int highlight) |
void | Initialize () |
int | HighlightHandle (vtkProp *prop) |
void | SizeHandles () override |
void | InsertHandleOnLine (double *pos) |
void | EraseHandle (const int &) |
void | RegisterPickers () override |
Register internal Pickers in the Picking Manager. | |
void | MovePoint (double *p1, double *p2) |
void | Scale (double *p1, double *p2, int X, int Y) |
void | Translate (double *p1, double *p2) |
void | Spin (double *p1, double *p2, double *vpn) |
void | CreateDefaultProperties () |
void | CalculateCentroid () |
Protected Member Functions inherited from vtk3DWidget | |
virtual vtkObjectBase * | NewInstanceInternal () const |
vtk3DWidget () | |
~vtk3DWidget () override | |
void | AdjustBounds (double bounds[6], double newBounds[6], double center[3]) |
double | SizeHandles (double factor) |
virtual void | SizeHandles () |
void | UpdateInput () |
Protected Member Functions inherited from vtkInteractorObserver | |
virtual vtkObjectBase * | NewInstanceInternal () const |
vtkInteractorObserver () | |
~vtkInteractorObserver () override | |
virtual void | RegisterPickers () |
Register internal Pickers in the Picking Manager. | |
void | UnRegisterPickers () |
Unregister internal pickers from the Picking Manager. | |
vtkPickingManager * | GetPickingManager () |
Return the picking manager associated on the context on which the observer currently belong. | |
vtkAssemblyPath * | GetAssemblyPath (double X, double Y, double Z, vtkAbstractPropPicker *picker) |
Proceed to a pick, whether through the PickingManager if the picking is managed or directly using the picker, and return the assembly path. | |
int | RequestCursorShape (int requestedShape) |
virtual void | StartInteraction () |
Utility routines used to start and end interaction. | |
virtual void | EndInteraction () |
Utility routines used to start and end interaction. | |
void | ComputeDisplayToWorld (double x, double y, double z, double worldPt[4]) |
Helper method for subclasses. | |
void | ComputeWorldToDisplay (double x, double y, double z, double displayPt[3]) |
Helper method for subclasses. | |
Protected Member Functions inherited from vtkObject | |
vtkObject () | |
~vtkObject () override | |
void | RegisterInternal (vtkObjectBase *, vtkTypeBool check) override |
void | UnRegisterInternal (vtkObjectBase *, vtkTypeBool check) override |
void | InternalGrabFocus (vtkCommand *mouseEvents, vtkCommand *keypressEvents=nullptr) |
These methods allow a command to exclusively grab all events. | |
void | InternalReleaseFocus () |
These methods allow a command to exclusively grab all events. | |
Protected Member Functions inherited from vtkObjectBase | |
vtkObjectBase () | |
virtual | ~vtkObjectBase () |
virtual void | RegisterInternal (vtkObjectBase *, vtkTypeBool check) |
virtual void | UnRegisterInternal (vtkObjectBase *, vtkTypeBool check) |
virtual void | ReportReferences (vtkGarbageCollector *) |
vtkObjectBase (const vtkObjectBase &) | |
void | operator= (const vtkObjectBase &) |
Static Protected Member Functions | |
static void | ProcessEventsHandler (vtkObject *object, unsigned long event, void *clientdata, void *calldata) |
Static Protected Member Functions inherited from vtkInteractorObserver | |
static void | ProcessEvents (vtkObject *object, unsigned long event, void *clientdata, void *calldata) |
Handles the char widget activation event. | |
Static Protected Member Functions inherited from vtkObjectBase | |
static vtkMallocingFunction | GetCurrentMallocFunction () |
static vtkReallocingFunction | GetCurrentReallocFunction () |
static vtkFreeingFunction | GetCurrentFreeFunction () |
static vtkFreeingFunction | GetAlternateFreeFunction () |
3D widget for manipulating a spline
This 3D widget defines a spline that can be interactively placed in a scene. The spline has handles, the number of which can be changed, plus it can be picked on the spline itself to translate or rotate it in the scene. A nice feature of the object is that the vtkSplineWidget, like any 3D widget, will work with the current interactor style. That is, if vtkSplineWidget does not handle an event, then all other registered observers (including the interactor style) have an opportunity to process the event. Otherwise, the vtkSplineWidget will terminate the processing of the event that it handles.
To use this object, just invoke SetInteractor() with the argument of the method a vtkRenderWindowInteractor. You may also wish to invoke "PlaceWidget()" to initially position the widget. The interactor will act normally until the "i" key (for "interactor") is pressed, at which point the vtkSplineWidget will appear. (See superclass documentation for information about changing this behavior.) Events that occur outside of the widget (i.e., no part of the widget is picked) are propagated to any other registered obsevers (such as the interaction style). Turn off the widget by pressing the "i" key again (or invoke the Off() method).
The button actions and key modifiers are as follows for controlling the widget: 1) left button down on and drag one of the spherical handles to change the shape of the spline: the handles act as "control points". 2) left button or middle button down on a line segment forming the spline allows uniform translation of the widget. 3) ctrl + middle button down on the widget enables spinning of the widget about its center. 4) right button down on the widget enables scaling of the widget. By moving the mouse "up" the render window the spline will be made bigger; by moving "down" the render window the widget will be made smaller. 5) ctrl key + right button down on any handle will erase it providing there will be two or more points remaining to form a spline. 6) shift key + right button down on any line segment will insert a handle onto the spline at the cursor position.
The vtkSplineWidget has several methods that can be used in conjunction with other VTK objects. The Set/GetResolution() methods control the number of subdivisions of the spline; the GetPolyData() method can be used to get the polygonal representation and can be used for things like seeding streamlines or probing other data sets. Typical usage of the widget is to make use of the StartInteractionEvent, InteractionEvent, and EndInteractionEvent events. The InteractionEvent is called on mouse motion; the other two events are called on button down and button up (either left or right button).
Some additional features of this class include the ability to control the properties of the widget. You can set the properties of the selected and unselected representations of the spline. For example, you can set the property for the handles and spline. In addition there are methods to constrain the spline so that it is aligned with a plane. Note that a simple ruler widget can be derived by setting the resolution to 1, the number of handles to 2, and calling the GetSummedLength method!
Definition at line 129 of file vtkSplineWidget.h.
Definition at line 137 of file vtkSplineWidget.h.
|
protected |
Enumerator | |
---|---|
Start | |
Moving | |
Scaling | |
Spinning | |
Inserting | |
Erasing | |
Outside |
Definition at line 316 of file vtkSplineWidget.h.
|
protected |
|
overrideprotected |
|
static |
Instantiate the object.
|
static |
|
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 vtk3DWidget.
|
static |
|
protectedvirtual |
Reimplemented from vtk3DWidget.
vtkSplineWidget * vtkSplineWidget::NewInstance | ( | ) | const |
|
overridevirtual |
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 vtk3DWidget.
|
overridevirtual |
Methods that satisfy the superclass' API.
Reimplemented from vtkInteractorObserver.
|
overridevirtual |
Methods that satisfy the superclass' API.
Implements vtk3DWidget.
|
inlineoverridevirtual |
Methods that satisfy the superclass' API.
Reimplemented from vtk3DWidget.
Definition at line 146 of file vtkSplineWidget.h.
|
inlineoverridevirtual |
Methods that satisfy the superclass' API.
Reimplemented from vtk3DWidget.
Definition at line 147 of file vtkSplineWidget.h.
|
virtual |
Force the spline widget to be projected onto one of the orthogonal planes.
Remember that when the state changes, a ModifiedEvent is invoked. This can be used to snap the spline to the plane if it is originally not aligned. The normal in SetProjectionNormal is 0,1,2 for YZ,XZ,XY planes respectively and 3 for arbitrary oblique planes when the widget is tied to a vtkPlaneSource.
|
virtual |
Force the spline widget to be projected onto one of the orthogonal planes.
Remember that when the state changes, a ModifiedEvent is invoked. This can be used to snap the spline to the plane if it is originally not aligned. The normal in SetProjectionNormal is 0,1,2 for YZ,XZ,XY planes respectively and 3 for arbitrary oblique planes when the widget is tied to a vtkPlaneSource.
|
virtual |
Force the spline widget to be projected onto one of the orthogonal planes.
Remember that when the state changes, a ModifiedEvent is invoked. This can be used to snap the spline to the plane if it is originally not aligned. The normal in SetProjectionNormal is 0,1,2 for YZ,XZ,XY planes respectively and 3 for arbitrary oblique planes when the widget is tied to a vtkPlaneSource.
|
virtual |
Force the spline widget to be projected onto one of the orthogonal planes.
Remember that when the state changes, a ModifiedEvent is invoked. This can be used to snap the spline to the plane if it is originally not aligned. The normal in SetProjectionNormal is 0,1,2 for YZ,XZ,XY planes respectively and 3 for arbitrary oblique planes when the widget is tied to a vtkPlaneSource.
void vtkSplineWidget::SetPlaneSource | ( | vtkPlaneSource * | plane | ) |
Set up a reference to a vtkPlaneSource that could be from another widget object, e.g.
|
virtual |
|
virtual |
|
inline |
Definition at line 176 of file vtkSplineWidget.h.
|
inline |
Definition at line 177 of file vtkSplineWidget.h.
|
inline |
Definition at line 178 of file vtkSplineWidget.h.
|
inline |
Definition at line 179 of file vtkSplineWidget.h.
void vtkSplineWidget::SetProjectionPosition | ( | double | position | ) |
Set the position of spline handles and points in terms of a plane's position.
i.e., if ProjectionNormal is 0, all of the x-coordinate values of the points are set to position. Any value can be passed (and is ignored) to update the spline points when Projection normal is set to 3 for arbitrary plane orientations.
|
virtual |
Set the position of spline handles and points in terms of a plane's position.
i.e., if ProjectionNormal is 0, all of the x-coordinate values of the points are set to position. Any value can be passed (and is ignored) to update the spline points when Projection normal is set to 3 for arbitrary plane orientations.
void vtkSplineWidget::GetPolyData | ( | vtkPolyData * | pd | ) |
Grab the polydata (including points) that defines the spline.
The polydata consists of points and line segments numbering Resolution + 1 and Resoltuion, respectively. Points are guaranteed to be up-to-date when either the InteractionEvent or EndInteraction events are invoked. The user provides the vtkPolyData and the points and polyline are added to it.
|
virtual |
Set/Get the handle properties (the spheres are the handles).
The properties of the handles when selected and unselected can be manipulated.
|
virtual |
Set/Get the handle properties (the spheres are the handles).
The properties of the handles when selected and unselected can be manipulated.
|
virtual |
Set/Get the handle properties (the spheres are the handles).
The properties of the handles when selected and unselected can be manipulated.
|
virtual |
Set/Get the handle properties (the spheres are the handles).
The properties of the handles when selected and unselected can be manipulated.
|
virtual |
Set/Get the line properties.
The properties of the line when selected and unselected can be manipulated.
|
virtual |
Set/Get the line properties.
The properties of the line when selected and unselected can be manipulated.
|
virtual |
Set/Get the line properties.
The properties of the line when selected and unselected can be manipulated.
|
virtual |
Set/Get the line properties.
The properties of the line when selected and unselected can be manipulated.
|
virtual |
Set/Get the number of handles for this widget.
|
virtual |
Set/Get the number of handles for this widget.
void vtkSplineWidget::SetResolution | ( | int | resolution | ) |
Set/Get the number of line segments representing the spline for this widget.
|
virtual |
Set/Get the number of line segments representing the spline for this widget.
|
virtual |
Set the parametric spline object.
Through vtkParametricSpline's API, the user can supply and configure one of currently two types of spline: vtkCardinalSpline, vtkKochanekSpline. The widget controls the open or closed configuration of the spline. WARNING: The widget does not enforce internal consistency so that all three are of the same type.
|
virtual |
Set the parametric spline object.
Through vtkParametricSpline's API, the user can supply and configure one of currently two types of spline: vtkCardinalSpline, vtkKochanekSpline. The widget controls the open or closed configuration of the spline. WARNING: The widget does not enforce internal consistency so that all three are of the same type.
void vtkSplineWidget::SetHandlePosition | ( | int | handle, |
double | x, | ||
double | y, | ||
double | z | ||
) |
Set/Get the position of the spline handles.
Call GetNumberOfHandles to determine the valid range of handle indices.
void vtkSplineWidget::SetHandlePosition | ( | int | handle, |
double | xyz[3] | ||
) |
Set/Get the position of the spline handles.
Call GetNumberOfHandles to determine the valid range of handle indices.
void vtkSplineWidget::GetHandlePosition | ( | int | handle, |
double | xyz[3] | ||
) |
Set/Get the position of the spline handles.
Call GetNumberOfHandles to determine the valid range of handle indices.
double * vtkSplineWidget::GetHandlePosition | ( | int | handle | ) |
Set/Get the position of the spline handles.
Call GetNumberOfHandles to determine the valid range of handle indices.
void vtkSplineWidget::SetClosed | ( | vtkTypeBool | closed | ) |
Control whether the spline is open or closed.
A closed spline forms a continuous loop: the first and last points are the same, and derivatives are continuous. A minimum of 3 handles are required to form a closed loop. This method enforces consistency with user supplied subclasses of vtkSpline.
|
virtual |
Control whether the spline is open or closed.
A closed spline forms a continuous loop: the first and last points are the same, and derivatives are continuous. A minimum of 3 handles are required to form a closed loop. This method enforces consistency with user supplied subclasses of vtkSpline.
|
virtual |
Control whether the spline is open or closed.
A closed spline forms a continuous loop: the first and last points are the same, and derivatives are continuous. A minimum of 3 handles are required to form a closed loop. This method enforces consistency with user supplied subclasses of vtkSpline.
|
virtual |
Control whether the spline is open or closed.
A closed spline forms a continuous loop: the first and last points are the same, and derivatives are continuous. A minimum of 3 handles are required to form a closed loop. This method enforces consistency with user supplied subclasses of vtkSpline.
int vtkSplineWidget::IsClosed | ( | ) |
Convenience method to determine whether the spline is closed in a geometric sense.
The widget may be set "closed" but still be geometrically open (e.g., a straight line).
double vtkSplineWidget::GetSummedLength | ( | ) |
Get the approximate vs.
the true arc length of the spline. Calculated as the summed lengths of the individual straight line segments. Use SetResolution to control the accuracy.
void vtkSplineWidget::InitializeHandles | ( | vtkPoints * | points | ) |
Convenience method to allocate and set the handles from a vtkPoints instance.
If the first and last points are the same, the spline sets Closed to the on state and disregards the last point, otherwise Closed remains unchanged.
|
virtual |
Turn on / off event processing for this widget.
If off, the widget will not respond to user interaction
|
virtual |
Turn on / off event processing for this widget.
If off, the widget will not respond to user interaction
|
virtual |
Turn on / off event processing for this widget.
If off, the widget will not respond to user interaction
|
virtual |
Turn on / off event processing for this widget.
If off, the widget will not respond to user interaction
|
staticprotected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
overrideprotectedvirtual |
Reimplemented from vtk3DWidget.
|
protected |
|
protected |
|
overrideprotectedvirtual |
Register internal Pickers in the Picking Manager.
Must be reimplemented by concrete widgets to register their pickers.
Reimplemented from vtkInteractorObserver.
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
Definition at line 315 of file vtkSplineWidget.h.
|
protected |
Definition at line 341 of file vtkSplineWidget.h.
|
protected |
Definition at line 342 of file vtkSplineWidget.h.
|
protected |
Definition at line 343 of file vtkSplineWidget.h.
|
protected |
Definition at line 344 of file vtkSplineWidget.h.
|
protected |
Definition at line 352 of file vtkSplineWidget.h.
|
protected |
Definition at line 353 of file vtkSplineWidget.h.
|
protected |
Definition at line 354 of file vtkSplineWidget.h.
|
protected |
Definition at line 355 of file vtkSplineWidget.h.
|
protected |
Definition at line 359 of file vtkSplineWidget.h.
|
protected |
Definition at line 361 of file vtkSplineWidget.h.
|
protected |
Definition at line 364 of file vtkSplineWidget.h.
|
protected |
Definition at line 365 of file vtkSplineWidget.h.
|
protected |
Definition at line 373 of file vtkSplineWidget.h.
|
protected |
Definition at line 374 of file vtkSplineWidget.h.
|
protected |
Definition at line 375 of file vtkSplineWidget.h.
|
protected |
Definition at line 376 of file vtkSplineWidget.h.
|
protected |
Definition at line 388 of file vtkSplineWidget.h.
|
protected |
Definition at line 392 of file vtkSplineWidget.h.
|
protected |
Definition at line 393 of file vtkSplineWidget.h.
|
protected |
Definition at line 394 of file vtkSplineWidget.h.
|
protected |
Definition at line 395 of file vtkSplineWidget.h.
|
protected |
Definition at line 399 of file vtkSplineWidget.h.
|
protected |
Definition at line 401 of file vtkSplineWidget.h.