Slicer 5.4
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
42class VTK_SLICER_MARKUPS_MODULE_MRMLDISPLAYABLEMANAGER_EXPORT vtkMRMLMarkupsDisplayableManager :
44{
45public:
46
47 // Allow the helper to call protected methods of displayable manager
49
52 void PrintSelf(ostream& os, vtkIndent indent) override;
53
57 virtual bool Is2DDisplayableManager();
60
62
63 bool CanProcessInteractionEvent(vtkMRMLInteractionEventData* eventData, double &closestDistance2) override;
65
66 void SetHasFocus(bool hasFocus, vtkMRMLInteractionEventData* eventData) override;
67 bool GetGrabFocus() override;
68 bool GetInteractive() override;
69 int GetMouseCursor() override;
70
71 // Updates markup point preview position.
72 // Returns true if the event is processed.
74
76
78
79 // Methods from vtkMRMLAbstractSliceViewDisplayableManager
80
84 void ConvertDeviceToXYZ(double x, double y, double xyz[3]);
85
88
89protected:
90
93
95
96 void ProcessMRMLNodesEvents(vtkObject *caller, unsigned long event, void *callData) override;
97
99 virtual void RequestRender();
100
103 void UpdateFromMRML() override;
104
105 void SetMRMLSceneInternal(vtkMRMLScene* newScene) override;
106
109 void UpdateFromMRMLScene() override;
110 void OnMRMLSceneEndClose() override;
111 void OnMRMLSceneEndImport() override;
112 void OnMRMLSceneNodeAdded(vtkMRMLNode* node) override;
114
117
119 void OnMRMLDisplayableNodeModifiedEvent(vtkObject* caller) override;
120
123
127
130
135 virtual bool IsManageable(vtkMRMLNode* node);
140 virtual bool IsManageable(const char* nodeClassName);
141
143 void OnInteractorStyleEvent(int eventid) override;
144
146 vtkGetMacro(DisableInteractorStyleEventsProcessing, int);
147
148 vtkSmartPointer<vtkMRMLMarkupsDisplayableManagerHelper> Helper;
149
150 double LastClickWorldCoordinates[4];
151
152 vtkWeakPointer<vtkSlicerMarkupsWidget> LastActiveWidget;
153
154private:
156 void operator=(const vtkMRMLMarkupsDisplayableManager&) = delete;
157
158 int DisableInteractorStyleEventsProcessing;
159
160 // by default, this displayableManager handles a 2d view, so the SliceNode
161 // must be set when it's assigned to a viewer
162 vtkWeakPointer<vtkMRMLSliceNode> SliceNode;
163};
164
165#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 OnInteractorStyleEvent(int eventid) override
Respond to interactor style events.
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.