Medical Imaging Interaction Toolkit  2025.12.02
Medical Imaging Interaction Toolkit
mitkOperation.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 mitkOperation_h
14 #define mitkOperation_h
15 
16 #include <MitkCoreExports.h>
17 #include <itkEventObject.h>
18 
19 #include <mitkCommon.h>
20 
21 namespace mitk
22 {
23  typedef int OperationType;
24 
25  //##Documentation
26  //## @brief Base class of all Operation-classes
27  //##
28  //## @ingroup Undo
30  {
31  public:
33 
34 
36  virtual bool IsValid() const;
37 
38  virtual ~Operation() = default;
40 
41  protected:
42  Operation(OperationType operationType);
43  Operation(const Operation&) = default;
44  Operation(Operation&&) = default;
45  Operation& operator=(const Operation&) = default;
46  Operation& operator=(Operation&&) = default;
47 
49  };
50 
51  class MITKCORE_EXPORT OperationEndEvent : public itk::EndEvent
52  {
53  public:
55  typedef itk::EndEvent Superclass;
56  OperationEndEvent(Operation *operation = nullptr) : m_Operation(operation) {}
57  ~OperationEndEvent() override {}
58  const char *GetEventName() const override { return "OperationEndEvent"; }
59  bool CheckEvent(const ::itk::EventObject *e) const override { return dynamic_cast<const Self *>(e); }
60  ::itk::EventObject *MakeObject() const override { return new Self(m_Operation); }
61  Operation *GetOperation() const { return m_Operation; }
62  private:
63  Operation *m_Operation;
64  OperationEndEvent(const Self &);
65  void operator=(const Self &);
66  };
67 
68 } // namespace mitk
69 #endif
#define MITKCORE_EXPORT
OperationEndEvent Self
Definition: mitkOperation.h:54
OperationEndEvent(Operation *operation=nullptr)
Definition: mitkOperation.h:56
itk::EndEvent Superclass
Definition: mitkOperation.h:55
bool CheckEvent(const ::itk::EventObject *e) const override
Definition: mitkOperation.h:59
const char * GetEventName() const override
Definition: mitkOperation.h:58
::itk::EventObject * MakeObject() const override
Definition: mitkOperation.h:60
Operation * GetOperation() const
Definition: mitkOperation.h:61
~OperationEndEvent() override
Definition: mitkOperation.h:57
Base class of all Operation-classes.
Definition: mitkOperation.h:30
OperationType m_OperationType
Definition: mitkOperation.h:48
virtual ~Operation()=default
Operation(const Operation &)=default
Operation & operator=(const Operation &)=default
OperationType GetOperationType()
Operation & operator=(Operation &&)=default
Operation(Operation &&)=default
mitkClassMacroNoParent(Operation) virtual bool IsValid() const
Operation(OperationType operationType)
Find image slices visible on a given plane.
int OperationType
Definition: mitkOperation.h:23