Slicer  4.11
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
vtkSlicerPlaneWidget.h
Go to the documentation of this file.
1 /*==============================================================================
2 
3  Copyright (c) Laboratory for Percutaneous Surgery (PerkLab)
4  Queen's University, Kingston, ON, Canada. All Rights Reserved.
5 
6  See COPYRIGHT.txt
7  or http://www.slicer.org/copyright/copyright.txt for details.
8 
9  Unless required by applicable law or agreed to in writing, software
10  distributed under the License is distributed on an "AS IS" BASIS,
11  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  See the License for the specific language governing permissions and
13  limitations under the License.
14 
15  This file was originally developed by Kyle Sunderland, PerkLab, Queen's University
16  and was supported through CANARIE's Research Software Program, Cancer
17  Care Ontario, OpenAnatomy, and Brigham and Women's Hospital through NIH grant R01MH112748.
18 
19 ==============================================================================*/
20 
29 #ifndef vtkSlicerPlaneWidget_h
30 #define vtkSlicerPlaneWidget_h
31 
32 #include "vtkSlicerMarkupsModuleVTKWidgetsExport.h"
33 #include "vtkSlicerMarkupsWidget.h"
34 
36 class vtkPolyData;
37 class vtkIdList;
38 
39 class VTK_SLICER_MARKUPS_MODULE_VTKWIDGETS_EXPORT vtkSlicerPlaneWidget : public vtkSlicerMarkupsWidget
40 {
41 public:
43  static vtkSlicerPlaneWidget *New();
44 
47 
49  enum
50  {
51  WidgetStateDefine = WidgetStateUser + 50, // click in empty area will place a new point
52  WidgetStateTranslatePlane, // translating the plane
53  };
54 
56  enum
57  {
58  WidgetEventControlPointPlace = WidgetEventUser + 50,
61  };
62 
64  void CreateDefaultRepresentation(vtkMRMLMarkupsDisplayNode* markupsDisplayNode, vtkMRMLAbstractViewNode* viewNode, vtkRenderer* renderer) override;
65 
66 protected:
68  ~vtkSlicerPlaneWidget() override;
69 
70  bool CanProcessInteractionEvent(vtkMRMLInteractionEventData* eventData, double& distance2) override;
71  bool ProcessInteractionEvent(vtkMRMLInteractionEventData* eventData) override;
72  bool ProcessPlaneMoveStart(vtkMRMLInteractionEventData* event);
73  bool ProcessPlaneMoveEnd(vtkMRMLInteractionEventData* event);
74  bool ProcessMouseMove(vtkMRMLInteractionEventData* eventData) override;
75  bool ProcessPlaneTranslate(vtkMRMLInteractionEventData* event);
76 
77 private:
79  void operator=(const vtkSlicerPlaneWidget&) = delete;
80 };
81 
82 #endif
Abstract MRML node to represent a view. The class holds the properties common to any view type (3D...
bool ProcessInteractionEvent(vtkMRMLInteractionEventData *eventData) override
Process interaction event.
Process interaction events to update state of markup widget nodes.
create a plane with a set of 3 points
bool CanProcessInteractionEvent(vtkMRMLInteractionEventData *eventData, double &distance2) override
Return true if the widget can process the event.
virtual void CreateDefaultRepresentation(vtkMRMLMarkupsDisplayNode *markupsDisplayNode, vtkMRMLAbstractViewNode *viewNode, vtkRenderer *renderer)=0
Create the default widget representation and initializes the widget and representation.
virtual bool ProcessMouseMove(vtkMRMLInteractionEventData *eventData)