VTK
vtkImplicitPlaneWidget.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkImplicitPlaneWidget.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 =========================================================================*/
72 #ifndef vtkImplicitPlaneWidget_h
73 #define vtkImplicitPlaneWidget_h
74 
75 #include "vtkInteractionWidgetsModule.h" // For export macro
77 
78 class vtkActor;
79 class vtkPolyDataMapper;
80 class vtkCellPicker;
81 class vtkConeSource;
82 class vtkLineSource;
83 class vtkSphereSource;
84 class vtkTubeFilter;
85 class vtkPlane;
86 class vtkCutter;
87 class vtkProperty;
88 class vtkImageData;
89 class vtkOutlineFilter;
90 class vtkFeatureEdges;
91 class vtkPolyData;
92 class vtkTransform;
93 
95 {
96 public:
98  static vtkImplicitPlaneWidget *New();
99 
101  void PrintSelf(ostream& os, vtkIndent indent);
102 
104 
105  virtual void SetEnabled(int);
106  virtual void PlaceWidget(double bounds[6]);
107  void PlaceWidget()
108  {this->Superclass::PlaceWidget();}
109  void PlaceWidget(double xmin, double xmax, double ymin, double ymax,
110  double zmin, double zmax)
111  {this->Superclass::PlaceWidget(xmin,xmax,ymin,ymax,zmin,zmax);}
113 
115 
116  virtual void SetOrigin(double x, double y, double z);
117  virtual void SetOrigin(double x[3]);
118  double* GetOrigin();
119  void GetOrigin(double xyz[3]);
121 
123 
124  void SetNormal(double x, double y, double z);
125  void SetNormal(double x[3]);
126  double* GetNormal();
127  void GetNormal(double xyz[3]);
129 
131 
135  void SetNormalToXAxis(int);
136  vtkGetMacro(NormalToXAxis,int);
137  vtkBooleanMacro(NormalToXAxis,int);
138  void SetNormalToYAxis(int);
139  vtkGetMacro(NormalToYAxis,int);
140  vtkBooleanMacro(NormalToYAxis,int);
141  void SetNormalToZAxis(int);
142  vtkGetMacro(NormalToZAxis,int);
143  vtkBooleanMacro(NormalToZAxis,int);
145 
147 
149  vtkSetMacro(Tubing,int);
150  vtkGetMacro(Tubing,int);
151  vtkBooleanMacro(Tubing,int);
153 
155 
159  void SetDrawPlane(int plane);
160  vtkGetMacro(DrawPlane,int);
161  vtkBooleanMacro(DrawPlane,int);
163 
165 
167  vtkSetMacro(OutlineTranslation,int);
168  vtkGetMacro(OutlineTranslation,int);
169  vtkBooleanMacro(OutlineTranslation,int);
171 
173 
175  vtkSetMacro(OutsideBounds,int);
176  vtkGetMacro(OutsideBounds,int);
177  vtkBooleanMacro(OutsideBounds,int);
179 
181 
182  vtkSetMacro(ScaleEnabled,int);
183  vtkGetMacro(ScaleEnabled,int);
184  vtkBooleanMacro(ScaleEnabled,int);
186 
188 
190  vtkSetMacro(OriginTranslation,int);
191  vtkGetMacro(OriginTranslation,int);
192  vtkBooleanMacro(OriginTranslation,int);
194 
196 
198  vtkSetClampMacro(DiagonalRatio,double,0,2);
199  vtkGetMacro(DiagonalRatio,double);
201 
204  void GetPolyData(vtkPolyData *pd);
205 
209 
214  void GetPlane(vtkPlane *plane);
215 
219  void UpdatePlacement();
220 
222  virtual void SizeHandles();
223 
225 
226  vtkGetObjectMacro(NormalProperty,vtkProperty);
227  vtkGetObjectMacro(SelectedNormalProperty,vtkProperty);
229 
231 
233  vtkGetObjectMacro(PlaneProperty,vtkProperty);
234  vtkGetObjectMacro(SelectedPlaneProperty,vtkProperty);
236 
238 
239  vtkGetObjectMacro(OutlineProperty,vtkProperty);
240  vtkGetObjectMacro(SelectedOutlineProperty,vtkProperty);
242 
244 
246  vtkGetObjectMacro(EdgesProperty,vtkProperty);
248 
249 protected:
252 
253 //BTX - manage the state of the widget
254  int State;
256  {
257  Start=0,
264  Outside
265  };
266 //ETX
267 
268  //handles the events
269  static void ProcessEvents(vtkObject* object, unsigned long event,
270  void* clientdata, void* calldata);
271 
272  // ProcessEvents() dispatches to these methods.
273  void OnLeftButtonDown();
274  void OnLeftButtonUp();
275  void OnMiddleButtonDown();
276  void OnMiddleButtonUp();
277  void OnRightButtonDown();
278  void OnRightButtonUp();
279  void OnMouseMove();
280 
281  // Controlling ivars
285  void UpdateRepresentation();
286 
287  // The actual plane which is being manipulated
289 
290  // The bounding box is represented by a single voxel image data
295  void HighlightOutline(int highlight);
296  int OutlineTranslation; //whether the outline can be moved
297  int ScaleEnabled; //whether the widget can be scaled
298  int OutsideBounds; //whether the widget can be moved outside input's bounds
299 
300  // The cut plane is produced with a vtkCutter
305  virtual void HighlightPlane(int highlight);
306 
307  // Optional tubes are represented by extracting boundary edges and tubing
312  int Tubing; //control whether tubing is on
313 
314  // Control final length of the arrow:
316 
317  // The + normal cone
321  void HighlightNormal(int highlight);
322 
323  // The + normal line
327 
328  // The - normal cone
332 
333  // The - normal line
337 
338  // The origin positioning handle
342  int OriginTranslation; //whether the origin (sphere) can be moved
343 
344  // Do the picking
346 
347  // Register internal Pickers within PickingManager
348  virtual void RegisterPickers();
349 
350  // Transform the normal (used for rotation)
352 
353  // Methods to manipulate the plane
354  void ConstrainOrigin(double x[3]);
355  void Rotate(int X, int Y, double *p1, double *p2, double *vpn);
356  void TranslatePlane(double *p1, double *p2);
357  void TranslateOutline(double *p1, double *p2);
358  void TranslateOrigin(double *p1, double *p2);
359  void Push(double *p1, double *p2);
360  void Scale(double *p1, double *p2, int X, int Y);
361 
362  // Properties used to control the appearance of selected objects and
363  // the manipulator in general.
371  void CreateDefaultProperties();
372 
373  void GeneratePlane();
374 
375 private:
376  vtkImplicitPlaneWidget(const vtkImplicitPlaneWidget&); //Not implemented
377  void operator=(const vtkImplicitPlaneWidget&); //Not implemented
378 };
379 
380 #endif
3D widget for manipulating an infinite plane
virtual vtkPolyDataAlgorithm * GetPolyDataAlgorithm()=0
void PrintSelf(ostream &os, vtkIndent indent)
Cut vtkDataSet with user-specified implicit function.
Definition: vtkCutter.h:68
represents an object (geometry & properties) in a rendered scene
Definition: vtkActor.h:50
abstract base class for most VTK objects
Definition: vtkObject.h:61
abstract PolyDataSource-based 3D widget
vtkPolyDataMapper * ConeMapper
represent surface properties of a geometric object
Definition: vtkProperty.h:63
vtkPolyDataMapper * EdgesMapper
static void ProcessEvents(vtkObject *object, unsigned long event, void *clientdata, void *calldata)
virtual void SetEnabled(int)
vtkPolyDataMapper * CutMapper
generate polygonal cone
Definition: vtkConeSource.h:43
describes linear transformations via a 4x4 matrix
Definition: vtkTransform.h:59
concrete dataset represents vertices, lines, polygons, and triangle strips
Definition: vtkPolyData.h:83
virtual void UpdatePlacement()=0
virtual void RegisterPickers()
#define VTKINTERACTIONWIDGETS_EXPORT
create wireframe outline for arbitrary data set
create a polygonal sphere centered at the origin
Superclass for algorithms that produce only polydata as output.
filter that generates tubes around lines
Definition: vtkTubeFilter.h:82
a simple class to control print indentation
Definition: vtkIndent.h:38
extract boundary, non-manifold, and/or sharp edges from polygonal data
topologically and geometrically regular array of data
Definition: vtkImageData.h:44
perform various plane computations
Definition: vtkPlane.h:36
vtkPolyDataMapper * OutlineMapper
vtkPolyDataMapper * ConeMapper2
virtual void PlaceWidget()
create a line defined by two end points
Definition: vtkLineSource.h:41
map vtkPolyData to graphics primitives
ray-cast cell picker for all kinds of Prop3Ds
Definition: vtkCellPicker.h:68
vtkPolyDataMapper * LineMapper
static vtkObject * New()
vtkPolyDataMapper * LineMapper2
virtual void SizeHandles()
Definition: vtk3DWidget.h:145
virtual void PlaceWidget()
void PlaceWidget(double xmin, double xmax, double ymin, double ymax, double zmin, double zmax)
vtkPolyDataMapper * SphereMapper