Medical Imaging Interaction Toolkit  2025.12.02
Medical Imaging Interaction Toolkit
mitkAffineBaseDataInteractor3D.h
Go to the documentation of this file.
1 /*============================================================================
2 
3 The Medical Imaging Interaction Toolkit (MITK)
4 
5 Copyright (c) German Cancer Research Center (DKFZ)
6 All rights reserved.
7 
8 Use of this source code is governed by a 3-clause BSD license that can be
9 found in the LICENSE file.
10 
11 ============================================================================*/
12 
13 #ifndef mitkAffineBaseDataInteractor3D_h
14 #define mitkAffineBaseDataInteractor3D_h
15 
17 #include <mitkDataInteractor.h>
18 #include <mitkGeometry3D.h>
19 
20 namespace mitk
21 {
23 #pragma GCC visibility push(default)
24  itkEventMacroDeclaration(AffineInteractionEvent, itk::AnyEvent);
25  itkEventMacroDeclaration(ScaleEvent, AffineInteractionEvent);
26  itkEventMacroDeclaration(RotateEvent, AffineInteractionEvent);
27  itkEventMacroDeclaration(TranslateEvent, AffineInteractionEvent);
28 #pragma GCC visibility pop
29 
35  // Inherit from DataInteractor, this provides functionality of a state machine and configurable inputs.
37  {
38  public:
40  itkFactorylessNewMacro(Self);
41  itkCloneMacro(Self);
42 
43  void SetDataNode(DataNode *node) override;
45  void RotateGeometry(mitk::ScalarType angle, int rotationaxis, mitk::BaseGeometry *geometry);
46  void ScaleGeometry(mitk::Point3D newScale, mitk::BaseGeometry *geometry);
48 
49  protected:
56  void ConnectActionsAndFunctions() override;
60  void DataNodeChanged() override;
61 
65  virtual bool CheckOverObject(const InteractionEvent *);
73  virtual void TranslateUpKey(StateMachineAction *, InteractionEvent *interactionEvent);
74  virtual void TranslateDownKey(StateMachineAction *, InteractionEvent *interactionEvent);
75  virtual void TranslateLeftKey(StateMachineAction *, InteractionEvent *interactionEvent);
76  virtual void TranslateRightKey(StateMachineAction *, InteractionEvent *interactionEvent);
77  virtual void TranslateUpModifierKey(StateMachineAction *, InteractionEvent *interactionEvent);
78  virtual void TranslateDownModifierKey(StateMachineAction *, InteractionEvent *interactionEvent);
79 
80  virtual void RotateUpKey(StateMachineAction *, InteractionEvent *interactionEvent);
81  virtual void RotateDownKey(StateMachineAction *, InteractionEvent *interactionEvent);
82  virtual void RotateLeftKey(StateMachineAction *, InteractionEvent *interactionEvent);
83  virtual void RotateRightKey(StateMachineAction *, InteractionEvent *interactionEvent);
84  virtual void RotateUpModifierKey(StateMachineAction *, InteractionEvent *interactionEvent);
85  virtual void RotateDownModifierKey(StateMachineAction *, InteractionEvent *interactionEvent);
86 
87  virtual void ScaleDownKey(mitk::StateMachineAction *, mitk::InteractionEvent *interactionEvent);
88  virtual void ScaleUpKey(mitk::StateMachineAction *, mitk::InteractionEvent *interactionEvent);
89 
90  virtual void RestoreNodeProperties();
91 
96  bool InitMembers(InteractionEvent *interactionEvent);
97 
98  private:
99  Point3D m_InitialPickedWorldPoint;
100  Point2D m_InitialPickedDisplayPoint;
101 
102  Geometry3D::Pointer m_OriginalGeometry;
103  };
104 }
105 #endif
#define MITKDATATYPESEXT_EXPORT
Affine interaction with mitk::BaseGeometry.
virtual void RotateObject(StateMachineAction *, InteractionEvent *)
virtual bool CheckOverObject(const InteractionEvent *)
virtual void ScaleDownKey(mitk::StateMachineAction *, mitk::InteractionEvent *interactionEvent)
mitkClassMacro(AffineBaseDataInteractor3D, DataInteractor)
virtual void TranslateUpModifierKey(StateMachineAction *, InteractionEvent *interactionEvent)
mitk::BaseGeometry * GetUpdatedTimeGeometry(mitk::InteractionEvent *interactionEvent)
virtual void RotateUpModifierKey(StateMachineAction *, InteractionEvent *interactionEvent)
virtual void RotateDownModifierKey(StateMachineAction *, InteractionEvent *interactionEvent)
virtual void ScaleObject(StateMachineAction *, InteractionEvent *)
virtual void RotateUpKey(StateMachineAction *, InteractionEvent *interactionEvent)
virtual void InitTranslate(StateMachineAction *, InteractionEvent *)
virtual void RotateDownKey(StateMachineAction *, InteractionEvent *interactionEvent)
virtual void RotateLeftKey(StateMachineAction *, InteractionEvent *interactionEvent)
void RotateGeometry(mitk::ScalarType angle, int rotationaxis, mitk::BaseGeometry *geometry)
bool InitMembers(InteractionEvent *interactionEvent)
InitMembers convenience method to avoid code duplication between InitRotate() and InitTranslate().
virtual void DeselectObject(StateMachineAction *, InteractionEvent *)
virtual void TranslateUpKey(StateMachineAction *, InteractionEvent *interactionEvent)
virtual void TranslateDownKey(StateMachineAction *, InteractionEvent *interactionEvent)
void TranslateGeometry(mitk::Vector3D translate, mitk::BaseGeometry *geometry)
void ConnectActionsAndFunctions() override
virtual void TranslateObject(StateMachineAction *, InteractionEvent *)
virtual void RotateRightKey(StateMachineAction *, InteractionEvent *interactionEvent)
void ScaleGeometry(mitk::Point3D newScale, mitk::BaseGeometry *geometry)
virtual void ScaleUpKey(mitk::StateMachineAction *, mitk::InteractionEvent *interactionEvent)
virtual void TranslateRightKey(StateMachineAction *, InteractionEvent *interactionEvent)
void SetDataNode(DataNode *node) override
virtual void TranslateLeftKey(StateMachineAction *, InteractionEvent *interactionEvent)
virtual void InitRotate(StateMachineAction *, InteractionEvent *)
virtual void TranslateDownModifierKey(StateMachineAction *, InteractionEvent *interactionEvent)
virtual void SelectObject(StateMachineAction *, InteractionEvent *)
BaseGeometry Describes the geometry of a data object.
Base class from with interactors that handle DataNodes are to be derived.
Class for nodes of the DataTree.
Definition: mitkDataNode.h:64
Represents an action, that is executed after a certain event (in statemachine-mechanism) TODO: implem...
Find image slices visible on a given plane.
double ScalarType
itkEventMacroDeclaration(BoundingShapeInteractionEvent, itk::AnyEvent)