VTK
vtkBorderWidget.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkBorderWidget.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 =========================================================================*/
76 #ifndef vtkBorderWidget_h
77 #define vtkBorderWidget_h
78 
79 #include "vtkInteractionWidgetsModule.h" // For export macro
80 #include "vtkAbstractWidget.h"
81 
83 
84 
85 class VTKINTERACTIONWIDGETS_EXPORT vtkBorderWidget : public vtkAbstractWidget
86 {
87 public:
91  static vtkBorderWidget *New();
92 
94 
98  void PrintSelf(ostream& os, vtkIndent indent);
100 
102 
108  vtkSetMacro(Selectable,int);
109  vtkGetMacro(Selectable,int);
110  vtkBooleanMacro(Selectable,int);
112 
113 
115 
120  vtkSetMacro(Resizable,int);
121  vtkGetMacro(Resizable,int);
122  vtkBooleanMacro(Resizable,int);
124 
125 
132  {this->Superclass::SetWidgetRepresentation(reinterpret_cast<vtkWidgetRepresentation*>(r));}
133 
138  {return reinterpret_cast<vtkBorderRepresentation*>(this->WidgetRep);}
139 
143  virtual void CreateDefaultRepresentation();
144 
145 protected:
146  vtkBorderWidget();
147  ~vtkBorderWidget();
148 
154  virtual void SelectRegion(double eventPos[2]);
155 
156  //enable the selection of the region interior to the widget
159 
160  //processes the registered events
161  static void SelectAction(vtkAbstractWidget*);
162  static void TranslateAction(vtkAbstractWidget*);
163  static void EndSelectAction(vtkAbstractWidget*);
164  static void MoveAction(vtkAbstractWidget*);
165 
166  // Special internal methods to support subclasses handling events.
167  // If a non-zero value is returned, the subclass is handling the event.
168  virtual int SubclassSelectAction() {return 0;}
169  virtual int SubclassTranslateAction() {return 0;}
170  virtual int SubclassEndSelectAction() {return 0;}
171  virtual int SubclassMoveAction() {return 0;}
172 
173  // helper methods for cursoe management
174  virtual void SetCursor(int State);
175 
176  //widget state
178  enum _WidgetState{Start=0,Define,Manipulate,Selected};
179 
180 private:
181  vtkBorderWidget(const vtkBorderWidget&) VTK_DELETE_FUNCTION;
182  void operator=(const vtkBorderWidget&) VTK_DELETE_FUNCTION;
183 };
184 
185 #endif
void PrintSelf(ostream &os, vtkIndent indent)
Standard macros implementing standard VTK methods.
virtual void SetCursor(int vtkNotUsed(state))
place a border around a 2D rectangular region
virtual int SubclassTranslateAction()
virtual void CreateDefaultRepresentation()=0
Create the default widget representation if one is not set.
virtual int SubclassMoveAction()
vtkWidgetRepresentation * WidgetRep
a simple class to control print indentation
Definition: vtkIndent.h:39
represent a vtkBorderWidget
virtual int SubclassEndSelectAction()
vtkSetMacro(IgnoreDriverBugs, bool)
When set known driver bugs are ignored during driver feature detection.
define the API for widget / widget representation
vtkBorderRepresentation * GetBorderRepresentation()
Return the representation as a vtkBorderRepresentation.
virtual int SubclassSelectAction()
void SetRepresentation(vtkBorderRepresentation *r)
Specify an instance of vtkWidgetRepresentation used to represent this widget in the scene...
vtkBooleanMacro(IgnoreDriverBugs, bool)
When set known driver bugs are ignored during driver feature detection.
static vtkObject * New()
Create an object with Debug turned off, modified time initialized to zero, and reference counting on...