VTK  9.1.0
vtkPlaneWidget.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkPlaneWidget.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
100 #ifndef vtkPlaneWidget_h
101 #define vtkPlaneWidget_h
102 
103 #include "vtkInteractionWidgetsModule.h" // For export macro
104 #include "vtkPolyDataSourceWidget.h"
105 
106 class vtkActor;
107 class vtkCellPicker;
108 class vtkConeSource;
109 class vtkLineSource;
110 class vtkPlaneSource;
111 class vtkPoints;
112 class vtkPolyData;
113 class vtkPolyDataMapper;
114 class vtkProp;
115 class vtkProperty;
116 class vtkSphereSource;
117 class vtkTransform;
118 class vtkPlane;
119 
120 #define VTK_PLANE_OFF 0
121 #define VTK_PLANE_OUTLINE 1
122 #define VTK_PLANE_WIREFRAME 2
123 #define VTK_PLANE_SURFACE 3
124 
125 #define VTK_PLANE_ZERO_THRESHOLD (std::numeric_limits<double>::min() * 1000)
126 
127 class VTKINTERACTIONWIDGETS_EXPORT vtkPlaneWidget : public vtkPolyDataSourceWidget
128 {
129 public:
133  static vtkPlaneWidget* New();
134 
136  void PrintSelf(ostream& os, vtkIndent indent) override;
137 
139 
142  void SetEnabled(int) override;
143  void PlaceWidget(double bounds[6]) override;
144  void PlaceWidget() override { this->Superclass::PlaceWidget(); }
146  double xmin, double xmax, double ymin, double ymax, double zmin, double zmax) override
147  {
148  this->Superclass::PlaceWidget(xmin, xmax, ymin, ymax, zmin, zmax);
149  }
151 
153 
156  void SetResolution(int r);
159 
161 
164  void SetOrigin(double x, double y, double z);
165  void SetOrigin(double x[3]);
166  double* GetOrigin() VTK_SIZEHINT(3);
167  void GetOrigin(double xyz[3]);
169 
171 
174  void SetPoint1(double x, double y, double z);
175  void SetPoint1(double x[3]);
176  double* GetPoint1() VTK_SIZEHINT(3);
177  void GetPoint1(double xyz[3]);
179 
181 
184  void SetPoint2(double x, double y, double z);
185  void SetPoint2(double x[3]);
186  double* GetPoint2() VTK_SIZEHINT(3);
187  void GetPoint2(double xyz[3]);
189 
191 
194  void SetCenter(double x, double y, double z);
195  void SetCenter(double x[3]);
196  double* GetCenter() VTK_SIZEHINT(3);
197  void GetCenter(double xyz[3]);
199 
201 
204  void SetNormal(double x, double y, double z);
205  void SetNormal(double x[3]);
206  double* GetNormal() VTK_SIZEHINT(3);
207  void GetNormal(double xyz[3]);
209 
211 
219  vtkSetClampMacro(Representation, int, VTK_PLANE_OFF, VTK_PLANE_SURFACE);
220  vtkGetMacro(Representation, int);
221  void SetRepresentationToOff() { this->SetRepresentation(VTK_PLANE_OFF); }
222  void SetRepresentationToOutline() { this->SetRepresentation(VTK_PLANE_OUTLINE); }
223  void SetRepresentationToWireframe() { this->SetRepresentation(VTK_PLANE_WIREFRAME); }
224  void SetRepresentationToSurface() { this->SetRepresentation(VTK_PLANE_SURFACE); }
226 
228 
234  vtkSetMacro(NormalToXAxis, vtkTypeBool);
235  vtkGetMacro(NormalToXAxis, vtkTypeBool);
236  vtkBooleanMacro(NormalToXAxis, vtkTypeBool);
237  vtkSetMacro(NormalToYAxis, vtkTypeBool);
238  vtkGetMacro(NormalToYAxis, vtkTypeBool);
239  vtkBooleanMacro(NormalToYAxis, vtkTypeBool);
240  vtkSetMacro(NormalToZAxis, vtkTypeBool);
241  vtkGetMacro(NormalToZAxis, vtkTypeBool);
242  vtkBooleanMacro(NormalToZAxis, vtkTypeBool);
244 
254 
262  void GetPlane(vtkPlane* plane);
263 
271 
276  void UpdatePlacement(void) override;
277 
279 
284  vtkGetObjectMacro(HandleProperty, vtkProperty);
285  vtkGetObjectMacro(SelectedHandleProperty, vtkProperty);
287 
289 
294  vtkGetObjectMacro(PlaneProperty, vtkProperty);
295  vtkGetObjectMacro(SelectedPlaneProperty, vtkProperty);
297 
298 protected:
300  ~vtkPlaneWidget() override;
301 
302  // Manage the state of the widget
303  int State;
305  {
306  Start = 0,
313  Pinching
314  };
315 
316  // handles the events
317  static void ProcessEvents(
318  vtkObject* object, unsigned long event, void* clientdata, void* calldata);
319 
320  // ProcessEvents() dispatches to these methods.
327  void OnMouseMove();
328  void OnStartPinch();
329  void OnPinch();
330  void OnEndPinch();
331 
332  // controlling ivars
338 
339  // the plane
344  void HighlightPlane(int highlight);
345 
346  // glyphs representing hot spots (e.g., handles)
351  void HandlesOn(double length);
352  void HandlesOff();
353  int HighlightHandle(vtkProp* prop); // returns cell id
354  void SizeHandles() override;
355 
356  // the normal cone
360  void HighlightNormal(int highlight);
361 
362  // the normal line
366 
367  // the normal cone
371 
372  // the normal line
376 
377  // Do the picking
381 
382  // Register internal Pickers within PickingManager
383  void RegisterPickers() override;
384 
385  // Methods to manipulate the hexahedron.
386  void MoveOrigin(double* p1, double* p2);
387  void MovePoint1(double* p1, double* p2);
388  void MovePoint2(double* p1, double* p2);
389  void MovePoint3(double* p1, double* p2);
390  void Rotate(int X, int Y, double* p1, double* p2, double* vpn);
391  void Spin(double* p1, double* p2);
392  void Scale(double* p1, double* p2, int X, int Y);
393  void Translate(double* p1, double* p2);
394  void Push(double* p1, double* p2);
395 
396  // Plane normal, normalized
397  double Normal[3];
398 
399  // Transform the hexahedral points (used for rotations)
401 
402  // Properties used to control the appearance of selected objects and
403  // the manipulator in general.
409 
411 
414 
415 private:
416  vtkPlaneWidget(const vtkPlaneWidget&) = delete;
417  void operator=(const vtkPlaneWidget&) = delete;
418 };
419 
420 #endif
vtkPolyDataMapper
map vtkPolyData to graphics primitives
Definition: vtkPolyDataMapper.h:146
vtkPoints
represent and manipulate 3D points
Definition: vtkPoints.h:143
vtkPlane
perform various plane computations
Definition: vtkPlane.h:143
vtkPlaneWidget::Scaling
@ Scaling
Definition: vtkPlaneWidget.h:308
vtkPlaneWidget::SelectRepresentation
void SelectRepresentation()
vtkPlaneWidget::OnEndPinch
void OnEndPinch()
vtkPlaneWidget::SetRepresentationToSurface
void SetRepresentationToSurface()
Control how the plane appears when GetPolyData() is invoked.
Definition: vtkPlaneWidget.h:224
vtkPlaneWidget::LineSource2
vtkLineSource * LineSource2
Definition: vtkPlaneWidget.h:375
vtkPlaneWidget::OnMiddleButtonUp
void OnMiddleButtonUp()
vtkPlaneWidget::ProcessEvents
static void ProcessEvents(vtkObject *object, unsigned long event, void *clientdata, void *calldata)
vtkPlaneWidget::RegisterPickers
void RegisterPickers() override
Register internal Pickers in the Picking Manager.
vtkPlaneWidget::HandlesOn
void HandlesOn(double length)
vtkPlaneWidget::CurrentHandle
vtkActor * CurrentHandle
Definition: vtkPlaneWidget.h:380
vtkPlaneWidget::ConeActor
vtkActor * ConeActor
Definition: vtkPlaneWidget.h:357
vtkPlaneWidget::Handle
vtkActor ** Handle
Definition: vtkPlaneWidget.h:347
vtkPlaneWidget::GetPolyData
void GetPolyData(vtkPolyData *pd)
Grab the polydata (including points) that defines the plane.
vtkPlaneWidget::WidgetState
WidgetState
Definition: vtkPlaneWidget.h:305
vtkPlaneSource
create an array of quadrilaterals located in a plane
Definition: vtkPlaneSource.h:164
vtkX3D::Normal
@ Normal
Definition: vtkX3D.h:51
vtkPlaneWidget::LineActor
vtkActor * LineActor
Definition: vtkPlaneWidget.h:363
vtkPlaneWidget::State
int State
Definition: vtkPlaneWidget.h:303
vtkPlaneWidget::Spin
void Spin(double *p1, double *p2)
vtkConeSource
generate polygonal cone
Definition: vtkConeSource.h:148
vtkObject
abstract base class for most VTK objects
Definition: vtkObject.h:82
vtkPlaneWidget::~vtkPlaneWidget
~vtkPlaneWidget() override
vtkPlaneWidget::SelectedHandleProperty
vtkProperty * SelectedHandleProperty
Definition: vtkPlaneWidget.h:405
vtkX3D::length
@ length
Definition: vtkX3D.h:399
vtkPlaneWidget::ConeSource2
vtkConeSource * ConeSource2
Definition: vtkPlaneWidget.h:370
vtkPlaneWidget::Pushing
@ Pushing
Definition: vtkPlaneWidget.h:309
vtkPlaneWidget::ConeSource
vtkConeSource * ConeSource
Definition: vtkPlaneWidget.h:359
vtkPlaneWidget::PlanePicker
vtkCellPicker * PlanePicker
Definition: vtkPlaneWidget.h:379
vtkPlaneWidget::NormalToXAxis
vtkTypeBool NormalToXAxis
Definition: vtkPlaneWidget.h:333
vtkPlaneWidget::GetPlane
void GetPlane(vtkPlane *plane)
Get the planes describing the implicit function defined by the plane widget.
vtkPlaneWidget::PlaneActor
vtkActor * PlaneActor
Definition: vtkPlaneWidget.h:340
vtkPlaneWidget::MovePoint1
void MovePoint1(double *p1, double *p2)
vtkTransform
describes linear transformations via a 4x4 matrix
Definition: vtkTransform.h:164
vtkPlaneWidget
3D widget for manipulating a finite plane
Definition: vtkPlaneWidget.h:128
vtkPlaneWidget::NormalToZAxis
vtkTypeBool NormalToZAxis
Definition: vtkPlaneWidget.h:335
vtkPlaneWidget::Rotate
void Rotate(int X, int Y, double *p1, double *p2, double *vpn)
vtkPlaneWidget::LineMapper2
vtkPolyDataMapper * LineMapper2
Definition: vtkPlaneWidget.h:374
vtkPlaneWidget::Spinning
@ Spinning
Definition: vtkPlaneWidget.h:311
vtkPlaneWidget::GeneratePlane
void GeneratePlane()
vtkPlaneWidget::HandleProperty
vtkProperty * HandleProperty
Definition: vtkPlaneWidget.h:404
vtkPlaneWidget::Scale
void Scale(double *p1, double *p2, int X, int Y)
vtkPlaneWidget::SetOrigin
void SetOrigin(double x, double y, double z)
Set/Get the origin of the plane.
VTK_SIZEHINT
#define VTK_SIZEHINT(...)
Definition: vtkWrappingHints.h:48
vtkPlaneWidget::GetPolyDataAlgorithm
vtkPolyDataAlgorithm * GetPolyDataAlgorithm() override
Satisfies superclass API.
vtkPlaneWidget::PlaneProperty
vtkProperty * PlaneProperty
Definition: vtkPlaneWidget.h:406
vtkPlaneWidget::SetRepresentationToOutline
void SetRepresentationToOutline()
Control how the plane appears when GetPolyData() is invoked.
Definition: vtkPlaneWidget.h:222
vtkPlaneWidget::UpdatePlacement
void UpdatePlacement(void) override
Satisfies superclass API.
vtkPlaneWidget::OnRightButtonUp
void OnRightButtonUp()
vtkSphereSource
create a polygonal sphere centered at the origin
Definition: vtkSphereSource.h:149
vtkPlaneWidget::SetEnabled
void SetEnabled(int) override
Methods that satisfy the superclass' API.
vtkPlaneWidget::LineMapper
vtkPolyDataMapper * LineMapper
Definition: vtkPlaneWidget.h:364
vtkPlaneWidget::PlaceWidget
void PlaceWidget() override
Methods that satisfy the superclass' API.
Definition: vtkPlaneWidget.h:144
vtkPlaneWidget::vtkPlaneWidget
vtkPlaneWidget()
vtkPlaneWidget::GetResolution
int GetResolution()
Set/Get the resolution (number of subdivisions) of the plane.
vtkActor
represents an object (geometry & properties) in a rendered scene
Definition: vtkActor.h:155
vtkPlaneWidget::MoveOrigin
void MoveOrigin(double *p1, double *p2)
vtkPlaneWidget::ConeActor2
vtkActor * ConeActor2
Definition: vtkPlaneWidget.h:368
vtkIndent
a simple class to control print indentation
Definition: vtkIndent.h:113
VTK_PLANE_WIREFRAME
#define VTK_PLANE_WIREFRAME
Definition: vtkPlaneWidget.h:122
vtkPlaneWidget::PlaneOutline
vtkPolyData * PlaneOutline
Definition: vtkPlaneWidget.h:343
vtkPlaneWidget::OnPinch
void OnPinch()
vtkPlaneWidget::LineActor2
vtkActor * LineActor2
Definition: vtkPlaneWidget.h:373
vtkPlaneWidget::LineSource
vtkLineSource * LineSource
Definition: vtkPlaneWidget.h:365
vtkPlaneWidget::GetOrigin
double * GetOrigin()
Set/Get the origin of the plane.
vtkPlaneWidget::LastPickValid
int LastPickValid
Definition: vtkPlaneWidget.h:412
vtkLineSource
create a line defined by two end points
Definition: vtkLineSource.h:170
vtkPlaneWidget::SetOrigin
void SetOrigin(double x[3])
Set/Get the origin of the plane.
vtkPlaneWidget::MovePoint3
void MovePoint3(double *p1, double *p2)
vtkPlaneWidget::SelectedPlaneProperty
vtkProperty * SelectedPlaneProperty
Definition: vtkPlaneWidget.h:407
vtkPlaneWidget::Representation
int Representation
Definition: vtkPlaneWidget.h:336
vtkProp
abstract superclass for all actors, volumes and annotations
Definition: vtkProp.h:76
vtkPlaneWidget::SetResolution
void SetResolution(int r)
Set/Get the resolution (number of subdivisions) of the plane.
vtkPlaneWidget::MovePoint2
void MovePoint2(double *p1, double *p2)
vtkPlaneWidget::HighlightNormal
void HighlightNormal(int highlight)
VTK_PLANE_SURFACE
#define VTK_PLANE_SURFACE
Definition: vtkPlaneWidget.h:123
vtkPlaneWidget::OnMouseMove
void OnMouseMove()
vtkPlaneWidget::HandlesOff
void HandlesOff()
vtkPlaneWidget::PlaceWidget
void PlaceWidget(double xmin, double xmax, double ymin, double ymax, double zmin, double zmax) override
Methods that satisfy the superclass' API.
Definition: vtkPlaneWidget.h:145
vtk3DWidget::PlaceWidget
virtual void PlaceWidget()
This method is used to initially place the widget.
vtkPlaneWidget::OnLeftButtonUp
void OnLeftButtonUp()
vtkPlaneWidget::Push
void Push(double *p1, double *p2)
VTK_PLANE_OFF
#define VTK_PLANE_OFF
Definition: vtkPlaneWidget.h:120
vtkPlaneWidget::ConeMapper
vtkPolyDataMapper * ConeMapper
Definition: vtkPlaneWidget.h:358
vtkPolyDataSourceWidget
abstract PolyDataSource-based 3D widget
Definition: vtkPolyDataSourceWidget.h:46
vtkPolyData
concrete dataset represents vertices, lines, polygons, and triangle strips
Definition: vtkPolyData.h:195
vtkPlaneWidget::OnRightButtonDown
void OnRightButtonDown()
vtkPlaneWidget::HandleGeometry
vtkSphereSource ** HandleGeometry
Definition: vtkPlaneWidget.h:349
vtkPlaneWidget::ConeMapper2
vtkPolyDataMapper * ConeMapper2
Definition: vtkPlaneWidget.h:369
vtkPlaneWidget::HandlePicker
vtkCellPicker * HandlePicker
Definition: vtkPlaneWidget.h:378
vtkPlaneWidget::OnMiddleButtonDown
void OnMiddleButtonDown()
vtkPlaneWidget::PlaceWidget
void PlaceWidget(double bounds[6]) override
Methods that satisfy the superclass' API.
vtkPlaneWidget::Translate
void Translate(double *p1, double *p2)
vtkPlaneWidget::PlaneMapper
vtkPolyDataMapper * PlaneMapper
Definition: vtkPlaneWidget.h:341
vtkPlaneWidget::OnStartPinch
void OnStartPinch()
vtkPlaneWidget::PrintSelf
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkPlaneWidget::SetRepresentationToWireframe
void SetRepresentationToWireframe()
Control how the plane appears when GetPolyData() is invoked.
Definition: vtkPlaneWidget.h:223
vtkProperty
represent surface properties of a geometric object
Definition: vtkProperty.h:171
vtkPlaneWidget::HighlightPlane
void HighlightPlane(int highlight)
vtkPlaneWidget::CreateDefaultProperties
void CreateDefaultProperties()
vtkPlaneWidget::SizeHandles
void SizeHandles() override
vtkPlaneWidget::Moving
@ Moving
Definition: vtkPlaneWidget.h:307
vtkPlaneWidget::PositionHandles
void PositionHandles()
vtkCellPicker
ray-cast cell picker for all kinds of Prop3Ds
Definition: vtkCellPicker.h:96
vtkPlaneWidget::HandleMapper
vtkPolyDataMapper ** HandleMapper
Definition: vtkPlaneWidget.h:348
vtkPlaneWidget::OnLeftButtonDown
void OnLeftButtonDown()
vtkPlaneWidget::New
static vtkPlaneWidget * New()
Instantiate the object.
vtkTypeBool
int vtkTypeBool
Definition: vtkABI.h:69
vtkPlaneWidget::SetPlaneProperty
virtual void SetPlaneProperty(vtkProperty *)
Get the plane properties.
vtkPlaneWidget::Transform
vtkTransform * Transform
Definition: vtkPlaneWidget.h:400
vtkPlaneWidget::PlaneSource
vtkPlaneSource * PlaneSource
Definition: vtkPlaneWidget.h:342
vtkPlaneWidget::Outside
@ Outside
Definition: vtkPlaneWidget.h:312
vtkPlaneWidget::Rotating
@ Rotating
Definition: vtkPlaneWidget.h:310
vtkPlaneWidget::HandleSizeFactor
double HandleSizeFactor
Definition: vtkPlaneWidget.h:413
vtkPlaneWidget::HighlightHandle
int HighlightHandle(vtkProp *prop)
vtkPolyDataSourceWidget.h
VTK_PLANE_OUTLINE
#define VTK_PLANE_OUTLINE
Definition: vtkPlaneWidget.h:121
vtkPlaneWidget::NormalToYAxis
vtkTypeBool NormalToYAxis
Definition: vtkPlaneWidget.h:334
vtkPolyDataAlgorithm
Superclass for algorithms that produce only polydata as output.
Definition: vtkPolyDataAlgorithm.h:151