VTK
|
measure the angle between two rays (defined by three points) More...
#include <vtkAngleWidget.h>
measure the angle between two rays (defined by three points)
The vtkAngleWidget is used to measure the angle between two rays (defined by three points). The three points (two end points and a center) can be positioned independently, and when they are released, a special PlacePointEvent is invoked so that special operations may be take to reposition the point (snap to grid, etc.) The widget has two different modes of interaction: when initially defined (i.e., placing the three points) and then a manipulate mode (adjusting the position of the three points).
To use this widget, specify an instance of vtkAngleWidget and a representation (a subclass of vtkAngleRepresentation). The widget is implemented using three instances of vtkHandleWidget which are used to position the three points. The representations for these handle widgets are provided by the vtkAngleRepresentation.
LeftButtonPressEvent - add a point or select a handle MouseMoveEvent - position the second or third point, or move a handle LeftButtonReleaseEvent - release the selected handle
vtkWidgetEvent::AddPoint -- add one point; depending on the state it may the first, second or third point added. Or, if near a handle, select the handle. vtkWidgetEvent::Move -- position the second or third point, or move the handle depending on the state. vtkWidgetEvent::EndSelect -- the handle manipulation process has completed.
vtkCommand::StartInteractionEvent (beginning to interact) vtkCommand::EndInteractionEvent (completing interaction) vtkCommand::InteractionEvent (moving a handle) vtkCommand::PlacePointEvent (after a point is positioned; call data includes handle id (0,1,2))
Definition at line 90 of file vtkAngleWidget.h.
Standard methods for a VTK class.
Reimplemented from vtkAbstractWidget.
Definition at line 98 of file vtkAngleWidget.h.
anonymous enum |
Enum defining the state of the widget. By default the widget is in Start mode, and expects to be interactively placed. While placing the points the widget transitions to Define state. Once placed, the widget enters the Manipulate state. BTX
Definition at line 137 of file vtkAngleWidget.h.
vtkAngleWidget::vtkAngleWidget | ( | ) | [protected] |
vtkAngleWidget::~vtkAngleWidget | ( | ) | [protected] |
static vtkAngleWidget* vtkAngleWidget::New | ( | ) | [static] |
Instantiate this class.
Reimplemented from vtkObject.
static int vtkAngleWidget::IsTypeOf | ( | const char * | type | ) | [static] |
Standard methods for a VTK class.
Reimplemented from vtkAbstractWidget.
virtual int vtkAngleWidget::IsA | ( | const char * | type | ) | [virtual] |
Standard methods for a VTK class.
Reimplemented from vtkAbstractWidget.
static vtkAngleWidget* vtkAngleWidget::SafeDownCast | ( | vtkObjectBase * | o | ) | [static] |
Standard methods for a VTK class.
Reimplemented from vtkAbstractWidget.
virtual vtkObjectBase* vtkAngleWidget::NewInstanceInternal | ( | ) | const [protected, virtual] |
Standard methods for a VTK class.
Reimplemented from vtkAbstractWidget.
vtkAngleWidget* vtkAngleWidget::NewInstance | ( | ) | const |
Standard methods for a VTK class.
Reimplemented from vtkAbstractWidget.
void vtkAngleWidget::PrintSelf | ( | ostream & | os, |
vtkIndent | indent | ||
) | [virtual] |
Standard methods for a VTK class.
Reimplemented from vtkAbstractWidget.
virtual void vtkAngleWidget::SetEnabled | ( | int | ) | [virtual] |
The method for activating and deactivating this widget. This method must be overridden because it is a composite widget and does more than its superclasses' vtkAbstractWidget::SetEnabled() method.
Reimplemented from vtkAbstractWidget.
void vtkAngleWidget::SetRepresentation | ( | vtkAngleRepresentation * | r | ) | [inline] |
Specify an instance of vtkWidgetRepresentation used to represent this widget in the scene. Note that the representation is a subclass of vtkProp so it can be added to the renderer independent of the widget.
Definition at line 111 of file vtkAngleWidget.h.
void vtkAngleWidget::CreateDefaultRepresentation | ( | ) | [virtual] |
Create the default widget representation if one is not set.
Implements vtkAbstractWidget.
vtkAngleRepresentation* vtkAngleWidget::GetAngleRepresentation | ( | ) | [inline] |
Return the representation as a vtkAngleRepresentation.
Definition at line 120 of file vtkAngleWidget.h.
A flag indicates whether the angle is valid. The angle value only becomes valid after two of the three points are placed.
virtual void vtkAngleWidget::SetProcessEvents | ( | int | ) | [virtual] |
Methods to change the whether the widget responds to interaction. Overridden to pass the state to component widgets.
Reimplemented from vtkAbstractWidget.
virtual void vtkAngleWidget::SetWidgetStateToStart | ( | ) | [virtual] |
Set the state of the widget. If the state is set to "Manipulate" then it is assumed that the widget and its representation will be initialized programmatically and is not interactively placed. Initially the widget state is set to "Start" which means nothing will appear and the user must interactively place the widget with repeated mouse selections. Set the state to "Start" if you want interactive placement. Generally state changes must be followed by a Render() for things to visually take effect.
virtual void vtkAngleWidget::SetWidgetStateToManipulate | ( | ) | [virtual] |
Set the state of the widget. If the state is set to "Manipulate" then it is assumed that the widget and its representation will be initialized programmatically and is not interactively placed. Initially the widget state is set to "Start" which means nothing will appear and the user must interactively place the widget with repeated mouse selections. Set the state to "Start" if you want interactive placement. Generally state changes must be followed by a Render() for things to visually take effect.
virtual int vtkAngleWidget::GetWidgetState | ( | ) | [inline, virtual] |
Return the current widget state.
Definition at line 156 of file vtkAngleWidget.h.
static void vtkAngleWidget::AddPointAction | ( | vtkAbstractWidget * | ) | [static, protected] |
static void vtkAngleWidget::MoveAction | ( | vtkAbstractWidget * | ) | [static, protected] |
static void vtkAngleWidget::EndSelectAction | ( | vtkAbstractWidget * | ) | [static, protected] |
void vtkAngleWidget::StartAngleInteraction | ( | int | handleNum | ) | [protected] |
void vtkAngleWidget::AngleInteraction | ( | int | handleNum | ) | [protected] |
void vtkAngleWidget::EndAngleInteraction | ( | int | handleNum | ) | [protected] |
friend class vtkAngleWidgetCallback [friend] |
Definition at line 189 of file vtkAngleWidget.h.
int vtkAngleWidget::WidgetState [protected] |
Definition at line 165 of file vtkAngleWidget.h.
int vtkAngleWidget::CurrentHandle [protected] |
Definition at line 166 of file vtkAngleWidget.h.
vtkHandleWidget* vtkAngleWidget::Point1Widget [protected] |
Definition at line 175 of file vtkAngleWidget.h.
vtkHandleWidget* vtkAngleWidget::CenterWidget [protected] |
Definition at line 176 of file vtkAngleWidget.h.
vtkHandleWidget* vtkAngleWidget::Point2Widget [protected] |
Definition at line 177 of file vtkAngleWidget.h.
Definition at line 178 of file vtkAngleWidget.h.
Definition at line 179 of file vtkAngleWidget.h.
Definition at line 180 of file vtkAngleWidget.h.