#include <vtkBoxWidget.h>
This 3D widget defines a region of interest that is represented by an arbitrarily oriented hexahedron with interior face angles of 90 degrees (orthogonal faces). The object creates 7 handles that can be moused on and manipulated. The first six correspond to the six faces, the seventh is in the center of the hexahedron. In addition, a bounding box outline is shown, the "faces" of which can be selected for object rotation or scaling. A nice feature of the object is that the vtkBoxWidget, like any 3D widget, will work with the current interactor style. That is, if vtkBoxWidget does not handle an event, then all other registered observers (including the interactor style) have an opportunity to process the event. Otherwise, the vtkBoxWidget 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 vtkBoxWidget will appear. (See superclass documentation for information about changing this behavior.) By grabbing the six face handles (use the left mouse button), faces can be moved. By grabbing the center handle (with the left mouse button), the entire hexahedron can be translated. (Translation can also be employed by using the "shift-left-mouse-button" combination inside of the widget.) Scaling is achieved by using the right mouse button "up" the render window (makes the widget bigger) or "down" the render window (makes the widget smaller). To rotate vtkBoxWidget, pick a face (but not a face handle) and move the left mouse. (Note: the mouse button must be held down during manipulation.) 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. (See the superclass documentation on key press activiation.)
The vtkBoxWidget is very flexible. It can be used to select, cut, clip, or perform any other operation that depends on an implicit function (use the GetPlanes() method); or it can be used to transform objects using a linear transformation (use the GetTransform() method). 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 rendered properties of the widget. You can set the properties of the selected and unselected representations of the parts of the widget. For example, you can set the property for the handles, faces, and outline in their normal and selected states.
The box widget can be oriented by specifying a transformation matrix. This transformation is applied to the initial bounding box as defined by the PlaceWidget() method. DO NOT ASSUME that the transformation is applied to a unit box centered at the origin; this is wrong!
Definition at line 104 of file vtkBoxWidget.h.
Public Types | |
typedef vtk3DWidget | Superclass |
Public Member Functions | |
virtual const char * | GetClassName () |
virtual int | IsA (const char *type) |
void | PrintSelf (ostream &os, vtkIndent indent) |
void | GetPlanes (vtkPlanes *planes) |
virtual void | GetTransform (vtkTransform *t) |
virtual void | SetTransform (vtkTransform *t) |
void | GetPolyData (vtkPolyData *pd) |
virtual void | SetEnabled (int) |
virtual void | PlaceWidget (double bounds[6]) |
void | PlaceWidget () |
void | PlaceWidget (double xmin, double xmax, double ymin, double ymax, double zmin, double zmax) |
virtual void | SetInsideOut (int) |
virtual int | GetInsideOut () |
virtual void | InsideOutOn () |
virtual void | InsideOutOff () |
virtual vtkProperty * | GetHandleProperty () |
virtual vtkProperty * | GetSelectedHandleProperty () |
void | HandlesOn () |
void | HandlesOff () |
virtual vtkProperty * | GetFaceProperty () |
virtual vtkProperty * | GetSelectedFaceProperty () |
virtual vtkProperty * | GetOutlineProperty () |
virtual vtkProperty * | GetSelectedOutlineProperty () |
void | SetOutlineFaceWires (int) |
virtual int | GetOutlineFaceWires () |
void | OutlineFaceWiresOn () |
void | OutlineFaceWiresOff () |
void | SetOutlineCursorWires (int) |
virtual int | GetOutlineCursorWires () |
void | OutlineCursorWiresOn () |
void | OutlineCursorWiresOff () |
virtual void | SetTranslationEnabled (int) |
virtual int | GetTranslationEnabled () |
virtual void | TranslationEnabledOn () |
virtual void | TranslationEnabledOff () |
virtual void | SetScalingEnabled (int) |
virtual int | GetScalingEnabled () |
virtual void | ScalingEnabledOn () |
virtual void | ScalingEnabledOff () |
virtual void | SetRotationEnabled (int) |
virtual int | GetRotationEnabled () |
virtual void | RotationEnabledOn () |
virtual void | RotationEnabledOff () |
Static Public Member Functions | |
static vtkBoxWidget * | New () |
static int | IsTypeOf (const char *type) |
static vtkBoxWidget * | SafeDownCast (vtkObject *o) |
Protected Types | |
enum | WidgetState { Start = 0, Moving, Scaling, Outside } |
Protected Member Functions | |
vtkBoxWidget () | |
~vtkBoxWidget () | |
virtual void | OnMouseMove () |
virtual void | OnLeftButtonDown () |
virtual void | OnLeftButtonUp () |
virtual void | OnMiddleButtonDown () |
virtual void | OnMiddleButtonUp () |
virtual void | OnRightButtonDown () |
virtual void | OnRightButtonUp () |
virtual void | PositionHandles () |
int | HighlightHandle (vtkProp *prop) |
void | HighlightFace (int cellId) |
void | HighlightOutline (int highlight) |
void | ComputeNormals () |
virtual void | SizeHandles () |
virtual void | Translate (double *p1, double *p2) |
virtual void | Scale (double *p1, double *p2, int X, int Y) |
virtual void | Rotate (int X, int Y, double *p1, double *p2, double *vpn) |
void | MovePlusXFace (double *p1, double *p2) |
void | MoveMinusXFace (double *p1, double *p2) |
void | MovePlusYFace (double *p1, double *p2) |
void | MoveMinusYFace (double *p1, double *p2) |
void | MovePlusZFace (double *p1, double *p2) |
void | MoveMinusZFace (double *p1, double *p2) |
void | MoveFace (double *p1, double *p2, double *dir, double *x1, double *x2, double *x3, double *x4, double *x5) |
void | GetDirection (const double Nx[3], const double Ny[3], const double Nz[3], double dir[3]) |
void | CreateDefaultProperties () |
void | GenerateOutline () |
Static Protected Member Functions | |
static void | ProcessEvents (vtkObject *object, unsigned long event, void *clientdata, void *calldata) |
Protected Attributes | |
int | State |
vtkActor * | HexActor |
vtkPolyDataMapper * | HexMapper |
vtkPolyData * | HexPolyData |
vtkPoints * | Points |
double | N [6][3] |
vtkActor * | HexFace |
vtkPolyDataMapper * | HexFaceMapper |
vtkPolyData * | HexFacePolyData |
vtkActor ** | Handle |
vtkPolyDataMapper ** | HandleMapper |
vtkSphereSource ** | HandleGeometry |
vtkActor * | HexOutline |
vtkPolyDataMapper * | OutlineMapper |
vtkPolyData * | OutlinePolyData |
vtkCellPicker * | HandlePicker |
vtkCellPicker * | HexPicker |
vtkActor * | CurrentHandle |
int | CurrentHexFace |
vtkTransform * | Transform |
vtkProperty * | HandleProperty |
vtkProperty * | SelectedHandleProperty |
vtkProperty * | FaceProperty |
vtkProperty * | SelectedFaceProperty |
vtkProperty * | OutlineProperty |
vtkProperty * | SelectedOutlineProperty |
int | InsideOut |
int | OutlineFaceWires |
int | OutlineCursorWires |
int | TranslationEnabled |
int | ScalingEnabled |
int | RotationEnabled |
typedef vtk3DWidget vtkBoxWidget::Superclass |
enum vtkBoxWidget::WidgetState [protected] |
vtkBoxWidget::vtkBoxWidget | ( | ) | [protected] |
vtkBoxWidget::~vtkBoxWidget | ( | ) | [protected] |
static vtkBoxWidget* vtkBoxWidget::New | ( | ) | [static] |
Instantiate the object.
Reimplemented from vtkObject.
virtual const char* vtkBoxWidget::GetClassName | ( | ) | [virtual] |
Reimplemented from vtk3DWidget.
static int vtkBoxWidget::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 vtk3DWidget.
virtual int vtkBoxWidget::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 vtk3DWidget.
static vtkBoxWidget* vtkBoxWidget::SafeDownCast | ( | vtkObject * | o | ) | [static] |
Reimplemented from vtk3DWidget.
void vtkBoxWidget::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 vtk3DWidget.
virtual void vtkBoxWidget::SetEnabled | ( | int | ) | [virtual] |
Methods that satisfy the superclass' API.
Reimplemented from vtkInteractorObserver.
virtual void vtkBoxWidget::PlaceWidget | ( | double | bounds[6] | ) | [virtual] |
Methods that satisfy the superclass' API.
Implements vtk3DWidget.
void vtkBoxWidget::PlaceWidget | ( | ) | [inline, virtual] |
Methods that satisfy the superclass' API.
Reimplemented from vtk3DWidget.
Definition at line 117 of file vtkBoxWidget.h.
void vtkBoxWidget::PlaceWidget | ( | double | xmin, | |
double | xmax, | |||
double | ymin, | |||
double | ymax, | |||
double | zmin, | |||
double | zmax | |||
) | [inline, virtual] |
Methods that satisfy the superclass' API.
Reimplemented from vtk3DWidget.
Definition at line 119 of file vtkBoxWidget.h.
void vtkBoxWidget::GetPlanes | ( | vtkPlanes * | planes | ) |
Get the planes describing the implicit function defined by the box widget. The user must provide the instance of the class vtkPlanes. Note that vtkPlanes is a subclass of vtkImplicitFunction, meaning that it can be used by a variety of filters to perform clipping, cutting, and selection of data. (The direction of the normals of the planes can be reversed enabling the InsideOut flag.)
virtual void vtkBoxWidget::SetInsideOut | ( | int | ) | [virtual] |
Set/Get the InsideOut flag. When off, the normals point out of the box. When on, the normals point into the hexahedron. InsideOut is off by default.
virtual int vtkBoxWidget::GetInsideOut | ( | ) | [virtual] |
Set/Get the InsideOut flag. When off, the normals point out of the box. When on, the normals point into the hexahedron. InsideOut is off by default.
virtual void vtkBoxWidget::InsideOutOn | ( | ) | [virtual] |
Set/Get the InsideOut flag. When off, the normals point out of the box. When on, the normals point into the hexahedron. InsideOut is off by default.
virtual void vtkBoxWidget::InsideOutOff | ( | ) | [virtual] |
Set/Get the InsideOut flag. When off, the normals point out of the box. When on, the normals point into the hexahedron. InsideOut is off by default.
virtual void vtkBoxWidget::GetTransform | ( | vtkTransform * | t | ) | [virtual] |
Retrieve a linear transform characterizing the transformation of the box. Note that the transformation is relative to where PlaceWidget was initially called. This method modifies the transform provided. The transform can be used to control the position of vtkProp3D's, as well as other transformation operations (e.g., vtkTranformPolyData).
virtual void vtkBoxWidget::SetTransform | ( | vtkTransform * | t | ) | [virtual] |
Set the position, scale and orientation of the box widget using the transform specified. Note that the transformation is relative to where PlaceWidget was initially called (i.e., the original bounding box).
void vtkBoxWidget::GetPolyData | ( | vtkPolyData * | pd | ) |
Grab the polydata (including points) that define the box widget. The polydata consists of 6 quadrilateral faces and 15 points. The first eight points define the eight corner vertices; the next six define the -x,+x, -y,+y, -z,+z face points; and the final point (the 15th out of 15 points) defines the center of the hexahedron. These point values are guaranteed to be up-to-date when either the InteractionEvent or EndInteractionEvent events are invoked. The user provides the vtkPolyData and the points and cells are added to it.
virtual vtkProperty* vtkBoxWidget::GetHandleProperty | ( | ) | [virtual] |
Get the handle properties (the little balls are the handles). The properties of the handles when selected and normal can be set.
virtual vtkProperty* vtkBoxWidget::GetSelectedHandleProperty | ( | ) | [virtual] |
Get the handle properties (the little balls are the handles). The properties of the handles when selected and normal can be set.
void vtkBoxWidget::HandlesOn | ( | ) |
Switches handles (the spheres) on or off by manipulating the actor visibility.
void vtkBoxWidget::HandlesOff | ( | ) |
Switches handles (the spheres) on or off by manipulating the actor visibility.
virtual vtkProperty* vtkBoxWidget::GetFaceProperty | ( | ) | [virtual] |
virtual vtkProperty* vtkBoxWidget::GetSelectedFaceProperty | ( | ) | [virtual] |
virtual vtkProperty* vtkBoxWidget::GetOutlineProperty | ( | ) | [virtual] |
Get the outline properties (the outline of the box). The properties of the outline when selected and normal can be set.
virtual vtkProperty* vtkBoxWidget::GetSelectedOutlineProperty | ( | ) | [virtual] |
Get the outline properties (the outline of the box). The properties of the outline when selected and normal can be set.
void vtkBoxWidget::SetOutlineFaceWires | ( | int | ) |
virtual int vtkBoxWidget::GetOutlineFaceWires | ( | ) | [virtual] |
void vtkBoxWidget::OutlineFaceWiresOn | ( | ) | [inline] |
Control the representation of the outline. This flag enables face wires. By default face wires are off.
Definition at line 197 of file vtkBoxWidget.h.
void vtkBoxWidget::OutlineFaceWiresOff | ( | ) | [inline] |
Control the representation of the outline. This flag enables face wires. By default face wires are off.
Definition at line 198 of file vtkBoxWidget.h.
void vtkBoxWidget::SetOutlineCursorWires | ( | int | ) |
Control the representation of the outline. This flag enables the cursor lines running between the handles. By default cursor wires are on.
virtual int vtkBoxWidget::GetOutlineCursorWires | ( | ) | [virtual] |
Control the representation of the outline. This flag enables the cursor lines running between the handles. By default cursor wires are on.
void vtkBoxWidget::OutlineCursorWiresOn | ( | ) | [inline] |
Control the representation of the outline. This flag enables the cursor lines running between the handles. By default cursor wires are on.
Definition at line 207 of file vtkBoxWidget.h.
void vtkBoxWidget::OutlineCursorWiresOff | ( | ) | [inline] |
Control the representation of the outline. This flag enables the cursor lines running between the handles. By default cursor wires are on.
Definition at line 208 of file vtkBoxWidget.h.
virtual void vtkBoxWidget::SetTranslationEnabled | ( | int | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual int vtkBoxWidget::GetTranslationEnabled | ( | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual void vtkBoxWidget::TranslationEnabledOn | ( | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual void vtkBoxWidget::TranslationEnabledOff | ( | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual void vtkBoxWidget::SetScalingEnabled | ( | int | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual int vtkBoxWidget::GetScalingEnabled | ( | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual void vtkBoxWidget::ScalingEnabledOn | ( | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual void vtkBoxWidget::ScalingEnabledOff | ( | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual void vtkBoxWidget::SetRotationEnabled | ( | int | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual int vtkBoxWidget::GetRotationEnabled | ( | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual void vtkBoxWidget::RotationEnabledOn | ( | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
virtual void vtkBoxWidget::RotationEnabledOff | ( | ) | [virtual] |
Control the behavior of the widget. Translation, rotation, and scaling can all be enabled and disabled.
static void vtkBoxWidget::ProcessEvents | ( | vtkObject * | object, | |
unsigned long | event, | |||
void * | clientdata, | |||
void * | calldata | |||
) | [static, protected] |
Handles the char widget activation event. Also handles the delete event.
Reimplemented from vtkInteractorObserver.
virtual void vtkBoxWidget::OnMouseMove | ( | ) | [protected, virtual] |
virtual void vtkBoxWidget::OnLeftButtonDown | ( | ) | [protected, virtual] |
virtual void vtkBoxWidget::OnLeftButtonUp | ( | ) | [protected, virtual] |
virtual void vtkBoxWidget::OnMiddleButtonDown | ( | ) | [protected, virtual] |
virtual void vtkBoxWidget::OnMiddleButtonUp | ( | ) | [protected, virtual] |
virtual void vtkBoxWidget::OnRightButtonDown | ( | ) | [protected, virtual] |
virtual void vtkBoxWidget::OnRightButtonUp | ( | ) | [protected, virtual] |
virtual void vtkBoxWidget::PositionHandles | ( | ) | [protected, virtual] |
int vtkBoxWidget::HighlightHandle | ( | vtkProp * | prop | ) | [protected] |
void vtkBoxWidget::HighlightFace | ( | int | cellId | ) | [protected] |
void vtkBoxWidget::HighlightOutline | ( | int | highlight | ) | [protected] |
void vtkBoxWidget::ComputeNormals | ( | ) | [protected] |
virtual void vtkBoxWidget::SizeHandles | ( | ) | [protected, virtual] |
Reimplemented from vtk3DWidget.
virtual void vtkBoxWidget::Translate | ( | double * | p1, | |
double * | p2 | |||
) | [protected, virtual] |
virtual void vtkBoxWidget::Scale | ( | double * | p1, | |
double * | p2, | |||
int | X, | |||
int | Y | |||
) | [protected, virtual] |
virtual void vtkBoxWidget::Rotate | ( | int | X, | |
int | Y, | |||
double * | p1, | |||
double * | p2, | |||
double * | vpn | |||
) | [protected, virtual] |
void vtkBoxWidget::MovePlusXFace | ( | double * | p1, | |
double * | p2 | |||
) | [protected] |
void vtkBoxWidget::MoveMinusXFace | ( | double * | p1, | |
double * | p2 | |||
) | [protected] |
void vtkBoxWidget::MovePlusYFace | ( | double * | p1, | |
double * | p2 | |||
) | [protected] |
void vtkBoxWidget::MoveMinusYFace | ( | double * | p1, | |
double * | p2 | |||
) | [protected] |
void vtkBoxWidget::MovePlusZFace | ( | double * | p1, | |
double * | p2 | |||
) | [protected] |
void vtkBoxWidget::MoveMinusZFace | ( | double * | p1, | |
double * | p2 | |||
) | [protected] |
void vtkBoxWidget::MoveFace | ( | double * | p1, | |
double * | p2, | |||
double * | dir, | |||
double * | x1, | |||
double * | x2, | |||
double * | x3, | |||
double * | x4, | |||
double * | x5 | |||
) | [protected] |
void vtkBoxWidget::GetDirection | ( | const double | Nx[3], | |
const double | Ny[3], | |||
const double | Nz[3], | |||
double | dir[3] | |||
) | [protected] |
void vtkBoxWidget::CreateDefaultProperties | ( | ) | [protected] |
void vtkBoxWidget::GenerateOutline | ( | ) | [protected] |
int vtkBoxWidget::State [protected] |
Definition at line 230 of file vtkBoxWidget.h.
vtkActor* vtkBoxWidget::HexActor [protected] |
Definition at line 256 of file vtkBoxWidget.h.
vtkPolyDataMapper* vtkBoxWidget::HexMapper [protected] |
Definition at line 257 of file vtkBoxWidget.h.
vtkPolyData* vtkBoxWidget::HexPolyData [protected] |
Definition at line 258 of file vtkBoxWidget.h.
vtkPoints* vtkBoxWidget::Points [protected] |
Definition at line 259 of file vtkBoxWidget.h.
double vtkBoxWidget::N[6][3] [protected] |
Definition at line 260 of file vtkBoxWidget.h.
vtkActor* vtkBoxWidget::HexFace [protected] |
Definition at line 263 of file vtkBoxWidget.h.
vtkPolyDataMapper* vtkBoxWidget::HexFaceMapper [protected] |
Definition at line 264 of file vtkBoxWidget.h.
vtkPolyData* vtkBoxWidget::HexFacePolyData [protected] |
Definition at line 265 of file vtkBoxWidget.h.
vtkActor** vtkBoxWidget::Handle [protected] |
Definition at line 268 of file vtkBoxWidget.h.
vtkPolyDataMapper** vtkBoxWidget::HandleMapper [protected] |
Definition at line 269 of file vtkBoxWidget.h.
vtkSphereSource** vtkBoxWidget::HandleGeometry [protected] |
Definition at line 270 of file vtkBoxWidget.h.
vtkActor* vtkBoxWidget::HexOutline [protected] |
Definition at line 279 of file vtkBoxWidget.h.
vtkPolyDataMapper* vtkBoxWidget::OutlineMapper [protected] |
Definition at line 280 of file vtkBoxWidget.h.
vtkPolyData* vtkBoxWidget::OutlinePolyData [protected] |
Definition at line 281 of file vtkBoxWidget.h.
vtkCellPicker* vtkBoxWidget::HandlePicker [protected] |
Definition at line 284 of file vtkBoxWidget.h.
vtkCellPicker* vtkBoxWidget::HexPicker [protected] |
Definition at line 285 of file vtkBoxWidget.h.
vtkActor* vtkBoxWidget::CurrentHandle [protected] |
Definition at line 286 of file vtkBoxWidget.h.
int vtkBoxWidget::CurrentHexFace [protected] |
Definition at line 287 of file vtkBoxWidget.h.
vtkTransform* vtkBoxWidget::Transform [protected] |
Definition at line 311 of file vtkBoxWidget.h.
vtkProperty* vtkBoxWidget::HandleProperty [protected] |
Definition at line 315 of file vtkBoxWidget.h.
vtkProperty* vtkBoxWidget::SelectedHandleProperty [protected] |
Definition at line 316 of file vtkBoxWidget.h.
vtkProperty* vtkBoxWidget::FaceProperty [protected] |
Definition at line 317 of file vtkBoxWidget.h.
vtkProperty* vtkBoxWidget::SelectedFaceProperty [protected] |
Definition at line 318 of file vtkBoxWidget.h.
vtkProperty* vtkBoxWidget::OutlineProperty [protected] |
Definition at line 319 of file vtkBoxWidget.h.
vtkProperty* vtkBoxWidget::SelectedOutlineProperty [protected] |
Definition at line 320 of file vtkBoxWidget.h.
int vtkBoxWidget::InsideOut [protected] |
Definition at line 324 of file vtkBoxWidget.h.
int vtkBoxWidget::OutlineFaceWires [protected] |
Definition at line 325 of file vtkBoxWidget.h.
int vtkBoxWidget::OutlineCursorWires [protected] |
Definition at line 326 of file vtkBoxWidget.h.
int vtkBoxWidget::TranslationEnabled [protected] |
Definition at line 330 of file vtkBoxWidget.h.
int vtkBoxWidget::ScalingEnabled [protected] |
Definition at line 331 of file vtkBoxWidget.h.
int vtkBoxWidget::RotationEnabled [protected] |
Definition at line 332 of file vtkBoxWidget.h.