Medical Imaging Interaction Toolkit  2023.12.00
Medical Imaging Interaction Toolkit
mitkTubeGraphProperty.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 mitkTubeGraphProperty_h
14 #define mitkTubeGraphProperty_h
15 
16 #include <MitkTubeGraphExports.h>
17 
18 #include "mitkTubeGraph.h"
19 #include <mitkBaseProperty.h>
20 #include <mitkColorProperty.h>
21 
22 #include <itkObject.h>
23 #include <map>
24 #include <vector>
25 
26 namespace mitk
27 {
32  {
33  public:
35  itkNewMacro(TubeGraphProperty);
36 
37  struct LabelGroup
38  {
39  struct Label
40  {
41  std::string labelName;
42  bool isVisible;
44  };
45  std::string labelGroupName;
46  std::vector<Label *> labels;
47  };
48 
51  typedef std::vector<TubeGraphProperty::LabelGroup *> LabelGroupSetType;
52  typedef std::pair<TubeDescriptorType, std::string> TubeToLabelGroupType;
54 
55  struct Annotation
56  {
57  std::string name;
58  std::string description;
60  };
61 
67  bool IsTubeVisible(const TubeDescriptorType &tube);
68 
74  void SetTubeActive(const TubeDescriptorType &tube, const bool &active);
75 
80  void SetTubesActive(std::vector<TubeDescriptorType> &tubes);
81 
87  bool IsTubeActive(const TubeDescriptorType &tube);
88 
89  std::vector<TubeDescriptorType> GetActiveTubes();
90 
91  Color GetColorOfTube(const TubeDescriptorType &tube);
92 
93  void SetTubesToLabels(std::map<TubeToLabelGroupType, std::string> tubeToLabelMap);
94 
95  std::map<TubeToLabelGroupType, std::string> GetTubesToLabels();
96 
100  void DeactivateAllTubes();
101 
102  void AddAnnotation(Annotation *annotation);
103  Annotation *GetAnnotationByName(std::string annotation);
104  std::vector<Annotation *> GetAnnotations();
105  void RemoveAnnotation(Annotation *annotation);
106 
107  void AddLabelGroup(LabelGroup *labelGroup, unsigned int position); // Add LG by name and vec<labelName>??
108  void RemoveLabelGroup(LabelGroup *labelGroup);
109  LabelGroupSetType GetLabelGroups();
110  unsigned int GetNumberOfLabelGroups();
111  unsigned int GetIndexOfLabelGroup(LabelGroup *labelGroup);
112  LabelGroup *GetLabelGroupByName(std::string labelGroup);
113 
114  void SetLabelVisibility(LabelGroup::Label *label, bool isVisible);
115  void SetLabelColor(LabelGroup::Label *label, Color color);
116  void RenameLabel(LabelGroup *labelGroup, LabelGroup::Label *label, std::string newName);
117  void SetLabelForActivatedTubes(LabelGroup *labelGroup, LabelGroup::Label *label);
118 
119  LabelGroup::Label *GetLabelByName(LabelGroup *labelGroup, std::string labelName);
120 
121  std::string GetValueAsString() const override;
122 
123  bool ToJSON(nlohmann::json& j) const override;
124  bool FromJSON(const nlohmann::json& j) override;
125 
126  protected:
128  TubeGraphProperty(const TubeGraphProperty &other);
129  ~TubeGraphProperty() override;
130 
131  private:
132  std::vector<TubeDescriptorType> m_ActiveTubes;
133  LabelGroupSetType m_LabelGroups;
134  std::map<TubeToLabelGroupType, std::string> m_TubeToLabelsMap;
135  std::vector<Annotation *> m_Annotations;
136 
137  bool TubeDescriptorsCompare(const TubeDescriptorType &tube1, const TubeDescriptorType &tube2);
138 
139  // purposely not implemented
140  TubeGraphProperty &operator=(const TubeGraphProperty &);
141 
142  bool IsEqual(const BaseProperty &property) const override;
143  bool Assign(const BaseProperty &property) override;
144  itk::LightObject::Pointer InternalClone() const override;
145  };
146 
147 } // namespace mitk
148 
149 #endif
mitk::TubeGraphProperty::LabelGroup::Label::isVisible
bool isVisible
Definition: mitkTubeGraphProperty.h:42
mitkTubeGraph.h
mitk::BaseProperty
Abstract base class for properties.
Definition: mitkBaseProperty.h:36
mitk::TubeGraphProperty::Annotation::description
std::string description
Definition: mitkTubeGraphProperty.h:58
mitk::TubeGraphProperty::TubeDescriptorType
TubeGraph::TubeDescriptorType TubeDescriptorType
Definition: mitkTubeGraphProperty.h:50
mitk::Color
itk::RGBPixel< float > Color
Color Standard RGB color typedef (float)
Definition: mitkColorProperty.h:38
mitk::TubeGraph::TubeDescriptorType
std::pair< VertexDescriptorType, VertexDescriptorType > TubeDescriptorType
Definition: mitkTubeGraph.h:49
mitk::TubeGraphProperty::Annotation::name
std::string name
Definition: mitkTubeGraphProperty.h:57
MITKTUBEGRAPH_EXPORT
#define MITKTUBEGRAPH_EXPORT
Definition: MitkTubeGraphExports.h:15
mitk::TubeGraphProperty::Annotation
Definition: mitkTubeGraphProperty.h:55
mitk
Find image slices visible on a given plane.
Definition: RenderingTests.dox:1
mitk::TubeGraphProperty
Property for tube graphs.
Definition: mitkTubeGraphProperty.h:31
mitk::TubeGraphProperty::LabelGroup::labels
std::vector< Label * > labels
Definition: mitkTubeGraphProperty.h:46
mitk::TubeGraphProperty::LabelGroup
Definition: mitkTubeGraphProperty.h:37
mitk::TubeGraphProperty::LabelGroup::Label::labelColor
Color labelColor
Definition: mitkTubeGraphProperty.h:43
json
nlohmann::json json
Definition: mitkModelTestFixture.h:29
mitk::TubeGraphProperty::Annotation::tube
TubeDescriptorType tube
Definition: mitkTubeGraphProperty.h:59
mitk::TubeGraphProperty::LabelGroup::Label
Definition: mitkTubeGraphProperty.h:39
mitk::TubeGraphProperty::TubeToLabelGroupType
std::pair< TubeDescriptorType, std::string > TubeToLabelGroupType
Definition: mitkTubeGraphProperty.h:52
mitkClassMacro
#define mitkClassMacro(className, SuperClassName)
Definition: mitkCommon.h:36
mitkColorProperty.h
mitk::TubeGraphProperty::LabelGroupSetType
std::vector< TubeGraphProperty::LabelGroup * > LabelGroupSetType
Definition: mitkTubeGraphProperty.h:51
mitk::TubeGraphProperty::LabelGroup::labelGroupName
std::string labelGroupName
Definition: mitkTubeGraphProperty.h:45
mitkBaseProperty.h
MitkTubeGraphExports.h
mitk::TubeGraphProperty::LabelGroup::Label::labelName
std::string labelName
Definition: mitkTubeGraphProperty.h:41