Slicer 5.6
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
Loading...
Searching...
No Matches
vtkMRMLMarkupsDisplayableManager.h
Go to the documentation of this file.
1/*==============================================================================
2
3 Program: 3D Slicer
4
5 Portions (c) Copyright Brigham and Women's Hospital (BWH) All Rights Reserved.
6
7 See COPYRIGHT.txt
8 or http://www.slicer.org/copyright/copyright.txt for details.
9
10 Unless required by applicable law or agreed to in writing, software
11 distributed under the License is distributed on an "AS IS" BASIS,
12 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 See the License for the specific language governing permissions and
14 limitations under the License.
15
16==============================================================================*/
17
18#ifndef __vtkMRMLMarkupsDisplayableManager_h
19#define __vtkMRMLMarkupsDisplayableManager_h
20
21// MarkupsModule includes
22#include "vtkSlicerMarkupsModuleMRMLDisplayableManagerExport.h"
23
24// MarkupsModule/MRMLDisplayableManager includes
26
27// MRMLDisplayableManager includes
29
30// VTK includes
32
33// STD includes
34#include <map>
35
37class vtkSlicerViewerWidget;
39class vtkAbstractWidget;
40
41class VTK_SLICER_MARKUPS_MODULE_MRMLDISPLAYABLEMANAGER_EXPORT vtkMRMLMarkupsDisplayableManager :
43{
44public:
45
46 // Allow the helper to call protected methods of displayable manager
48
51 void PrintSelf(ostream& os, vtkIndent indent) override;
52
56 virtual bool Is2DDisplayableManager();
59
61
62 bool CanProcessInteractionEvent(vtkMRMLInteractionEventData* eventData, double &closestDistance2) override;
64
65 void SetHasFocus(bool hasFocus, vtkMRMLInteractionEventData* eventData) override;
66 bool GetGrabFocus() override;
67 bool GetInteractive() override;
68 int GetMouseCursor() override;
69
70 // Updates markup point preview position.
71 // Returns true if the event is processed.
73
75
77
78 // Methods from vtkMRMLAbstractSliceViewDisplayableManager
79
83 void ConvertDeviceToXYZ(double x, double y, double xyz[3]);
84
87
88protected:
89
92
94
95 void ProcessMRMLNodesEvents(vtkObject *caller, unsigned long event, void *callData) override;
96
98 virtual void RequestRender();
99
102 void UpdateFromMRML() override;
103
104 void SetMRMLSceneInternal(vtkMRMLScene* newScene) override;
105
108 void UpdateFromMRMLScene() override;
109 void OnMRMLSceneEndClose() override;
110 void OnMRMLSceneEndImport() override;
111 void OnMRMLSceneNodeAdded(vtkMRMLNode* node) override;
113
116
118 void OnMRMLDisplayableNodeModifiedEvent(vtkObject* caller) override;
119
122
126
129
134 virtual bool IsManageable(vtkMRMLNode* node);
139 virtual bool IsManageable(const char* nodeClassName);
140
142 vtkGetMacro(DisableInteractorStyleEventsProcessing, int);
143
144 vtkSmartPointer<vtkMRMLMarkupsDisplayableManagerHelper> Helper;
145
146 double LastClickWorldCoordinates[4];
147
148 vtkWeakPointer<vtkSlicerMarkupsWidget> LastActiveWidget;
149
150private:
152 void operator=(const vtkMRMLMarkupsDisplayableManager&) = delete;
153
154 int DisableInteractorStyleEventsProcessing;
155
156 // by default, this displayableManager handles a 2d view, so the SliceNode
157 // must be set when it's assigned to a viewer
158 vtkWeakPointer<vtkMRMLSliceNode> SliceNode;
159};
160
161#endif
Superclass for displayable manager classes.
virtual bool IsManageable(const char *nodeClassName)
void SetMRMLSceneInternal(vtkMRMLScene *newScene) override
virtual void OnMRMLSliceNodeModifiedEvent()
Handler for specific SliceView actions, iterate over the widgets in the helper.
bool GetInteractive() override
Displayable manager can indicate that the window is in interactive mode (faster updates).
void ProcessMRMLNodesEvents(vtkObject *caller, unsigned long event, void *callData) override
vtkSlicerMarkupsWidget * GetWidget(vtkMRMLMarkupsDisplayNode *node)
Get the widget of a node.
void ConvertDeviceToXYZ(double x, double y, double xyz[3])
void OnMRMLSceneNodeRemoved(vtkMRMLNode *node) override
vtkMRMLSliceNode * GetMRMLSliceNode()
Get the sliceNode, if registered. This would mean it is a 2D SliceView displayableManager.
int GetMouseCursor() override
Displayable manager returns ID of the mouse cursor shape that should be displayed.
static vtkMRMLMarkupsDisplayableManager * New()
vtkMRMLMarkupsNode * GetActiveMarkupsNodeForPlacement()
vtkSlicerMarkupsWidget * FindClosestWidget(vtkMRMLInteractionEventData *callData, double &closestDistance2)
void PrintSelf(ostream &os, vtkIndent indent) override
void SetHasFocus(bool hasFocus, vtkMRMLInteractionEventData *eventData) override
Set if the widget gets/loses focus (interaction events are processed by this displayable manager).
virtual bool IsManageable(vtkMRMLNode *node)
vtkSlicerMarkupsWidget * GetWidgetForPlacement()
bool CanProcessInteractionEvent(vtkMRMLInteractionEventData *eventData, double &closestDistance2) override
vtkSlicerMarkupsWidget * CreateWidget(vtkMRMLMarkupsDisplayNode *node)
Create a widget.
void AddObserversToInteractionNode()
Observe the interaction node.
void OnMRMLDisplayableNodeModifiedEvent(vtkObject *caller) override
Called after the corresponding MRML View container was modified.
virtual void RequestRender()
Wrap the superclass render request in a check for batch processing.
vtkMRMLMarkupsDisplayableManagerHelper * GetHelper()
vtkSmartPointer< vtkMRMLMarkupsDisplayableManagerHelper > Helper
void OnMRMLSceneNodeAdded(vtkMRMLNode *node) override
vtkWeakPointer< vtkSlicerMarkupsWidget > LastActiveWidget
virtual bool IsCorrectDisplayableManager()
Check if it is the right displayManager.
bool GetGrabFocus() override
Displayable manager can indicate that it would like to get all events (even when mouse pointer is out...
void OnMRMLSceneEndImport() override
bool ProcessInteractionEvent(vtkMRMLInteractionEventData *eventData) override
Abstract Superclass for all specific types of MRML nodes.
A set of MRML Nodes that supports serialization and undo/redo.
MRML node for storing a slice through RAS space.
Process interaction events to update state of markup widget nodes.