Slicer 5.6
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
Loading...
Searching...
No Matches
vtkMRMLSegmentationDisplayNode.h
Go to the documentation of this file.
1/*==============================================================================
2
3 Program: 3D Slicer
4
5 Copyright (c) Laboratory for Percutaneous Surgery (PerkLab)
6 Queen's University, Kingston, ON, Canada. All Rights Reserved.
7
8 See COPYRIGHT.txt
9 or http://www.slicer.org/copyright/copyright.txt for details.
10
11 Unless required by applicable law or agreed to in writing, software
12 distributed under the License is distributed on an "AS IS" BASIS,
13 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 See the License for the specific language governing permissions and
15 limitations under the License.
16
17 This file was originally developed by Csaba Pinter, PerkLab, Queen's University
18 and was supported through the Applied Cancer Research Unit program of Cancer Care
19 Ontario with funds provided by the Ontario Ministry of Health and Long-Term Care
20
21==============================================================================*/
22
23#ifndef __vtkMRMLSegmentationDisplayNode_h
24#define __vtkMRMLSegmentationDisplayNode_h
25
26#include "vtkMRMLDisplayNode.h"
27
28#include <set>
29
31class vtkSegmentation;
32class vtkStringArray;
33class vtkVector3d;
34
35
40{
41public:
42 // Define constants
43 static const double SEGMENT_COLOR_NO_OVERRIDE;
44
47 {
50 double OverrideColor[3];
52 bool Visible{true}; // Turns visibility on/off in general. Useful for allowing the user to show/hide a segment without changing any detailed visibility options.
53 bool Visible3D{true};
54 bool Visible2DFill{true}; // This one is used for labelmap volume related operations (color table, merged labelmap)
55 bool Visible2DOutline{true};
57 double Opacity3D{1.0};
58 double Opacity2DFill{1.0}; // This one is used for labelmap volume related operations (color table, merged labelmap)
59 double Opacity2DOutline{1.0};
61 bool Pickable{true};
62
63 // Initialize with default values
65 {
66 OverrideColor[0] = SEGMENT_COLOR_NO_OVERRIDE;
67 OverrideColor[1] = SEGMENT_COLOR_NO_OVERRIDE;
68 OverrideColor[2] = SEGMENT_COLOR_NO_OVERRIDE;
69 }
70
71 // Automatically generated operator= and copy constructor work
72 // correctly for these members, so there is no need to define them.
73 };
74
75 typedef std::map<std::string, SegmentDisplayProperties> SegmentDisplayPropertiesMap;
76
77public:
80 void PrintSelf(ostream& os, vtkIndent indent) override;
81
83
85 void ReadXMLAttributes( const char** atts) override;
86
88 void WriteXML(ostream& of, int indent) override;
89
93
95 const char* GetNodeTagName() override { return "SegmentationDisplay"; }
96
97public:
100 vtkGetStringMacro(PreferredDisplayRepresentationName2D);
102 vtkSetStringMacro(PreferredDisplayRepresentationName2D);
104 vtkGetStringMacro(PreferredDisplayRepresentationName3D);
106 vtkSetStringMacro(PreferredDisplayRepresentationName3D);
107
109 vtkGetMacro(Visibility2DFill, bool);
110 vtkSetMacro(Visibility2DFill, bool);
111 vtkBooleanMacro(Visibility2DFill, bool);
113 vtkGetMacro(Visibility2DOutline, bool);
114 vtkSetMacro(Visibility2DOutline, bool);
115 vtkBooleanMacro(Visibility2DOutline, bool);
116
118 vtkGetMacro(Opacity3D, double);
119 vtkSetMacro(Opacity3D, double);
121 vtkGetMacro(Opacity2DFill, double);
122 vtkSetMacro(Opacity2DFill, double);
124 vtkGetMacro(Opacity2DOutline, double);
125 vtkSetMacro(Opacity2DOutline, double);
126
127public:
133 bool GetSegmentDisplayProperties(std::string segmentID, SegmentDisplayProperties &properties);
134
136 void SetSegmentDisplayProperties(std::string segmentID, SegmentDisplayProperties &properties);
137
139 void SetSegmentDisplayPropertiesToDefault(const std::string& segmentId);
140
142 void RemoveSegmentDisplayProperties(std::string segmentID);
143
146
151
158 void GenerateSegmentColor(double color[3], int colorNumber=0);
161 void GenerateSegmentColor(double &r, double &g, double &b);
162
164
166 void SetSegmentColorGeneratorSourceColorNodeID(const char* colorNodeID);
169
171 void GetPolyDataRepresentationNames(std::set<std::string> &representationNames);
172
179
184
185// Convenience and python compatibility functions
186public:
189 vtkVector3d GetSegmentColor(std::string segmentID);
191 bool GetSegmentColor(std::string segmentID, double* color);
193 bool GetSegmentColor(std::string segmentID, double &r, double &g, double &b);
194
197 vtkVector3d GetSegmentOverrideColor(std::string segmentID);
203 void SetSegmentOverrideColor(std::string segmentID, double r, double g, double b);
205 void SetSegmentOverrideColor(std::string segmentID, vtkVector3d overrideColor);
207 void UnsetSegmentOverrideColor(std::string segmentID);
208
211 bool GetSegmentVisibility(std::string segmentID);
213 void SetSegmentVisibility(std::string segmentID, bool visible);
214 void SetAllSegmentsVisibility(bool visible);
215
218 bool GetSegmentVisibility3D(std::string segmentID);
220 void SetSegmentVisibility3D(std::string segmentID, bool visible);
221 void SetAllSegmentsVisibility3D(bool visible, bool changeVisibleSegmentsOnly = false);
222
225 bool GetSegmentVisibility2DFill(std::string segmentID);
227 void SetSegmentVisibility2DFill(std::string segmentID, bool visible);
228 void SetAllSegmentsVisibility2DFill(bool visible, bool changeVisibleSegmentsOnly = false);
229
232 bool GetSegmentVisibility2DOutline(std::string segmentID);
234 void SetSegmentVisibility2DOutline(std::string segmentID, bool visible);
235 void SetAllSegmentsVisibility2DOutline(bool visible, bool changeVisibleSegmentsOnly = false);
236
239 double GetSegmentOpacity3D(std::string segmentID);
241 void SetSegmentOpacity3D(std::string segmentID, double opacity);
242 void SetAllSegmentsOpacity3D(double opacity, bool changeVisibleSegmentsOnly = false);
243
246 double GetSegmentOpacity2DFill(std::string segmentID);
248 void SetSegmentOpacity2DFill(std::string segmentID, double opacity);
249 void SetAllSegmentsOpacity2DFill(double opacity, bool changeVisibleSegmentsOnly = false);
250
253 double GetSegmentOpacity2DOutline(std::string segmentID);
255 void SetSegmentOpacity2DOutline(std::string segmentID, double opacity);
256 void SetAllSegmentsOpacity2DOutline(double opacity, bool changeVisibleSegmentsOnly = false);
257
259 void SetSegmentOpacity(std::string segmentID, double opacity);
260 void SetAllSegmentsOpacity(double opacity, bool changeVisibleSegmentsOnly = false);
261
264 bool GetSegmentPickable(std::string segmentID);
266 void SetSegmentPickable(std::string segmentID, bool pickable);
267 void SetAllSegmentsPickable(bool pickable, bool changeVisibleSegmentsOnly = false);
268
270 void GetVisibleSegmentIDs(vtkStringArray* segmentIDs);
271
273 void GetVisibleSegmentIDs(std::vector<std::string>& segmentIDs);
274
276 std::vector<std::string> GetVisibleSegmentIDs();
277
278protected:
280 void GetSegmentIDs(std::vector<std::string>& segmentIDs, bool visibleSegmentsOnly);
281
285 void UpdateSegmentList(bool removeUnusedDisplayProperties = true);
286
287protected:
292
293 friend class vtkMRMLSegmentationNode; // Access to UpdateSegmentList();
294
295protected:
298 char* PreferredDisplayRepresentationName2D{nullptr};
299
303 char* PreferredDisplayRepresentationName3D{nullptr};
304
308
311 unsigned int NumberOfGeneratedColors{0};
312
314 vtkMTimeType SegmentListUpdateTime{0};
315 vtkSegmentation* SegmentListUpdateSource{nullptr};
316
320 bool Visibility2DFill{true};
324 bool Visibility2DOutline{true};
325
327 double Opacity3D{1.0};
329 double Opacity2DFill{0.5};
331 double Opacity2DOutline{1.0};
332};
333
334#endif
MRML node to represent discrete color information.
Abstract class that contains graphical display properties for displayable nodes.
Abstract Superclass for all specific types of MRML nodes.
MRML node for representing segmentation display attributes.
bool GetSegmentVisibility3D(std::string segmentID)
bool GetSegmentVisibility2DOutline(std::string segmentID)
void RemoveSegmentDisplayProperties(std::string segmentID)
Remove segment display properties.
void SetSegmentOpacity(std::string segmentID, double opacity)
Set all three types of segment opacity by segment ID.
void SetSegmentVisibility3D(std::string segmentID, bool visible)
Set segment 3D visibility by segment ID. Convenience function for python compatibility.
void WriteXML(ostream &of, int indent) override
Write this node's information to a MRML file in XML format.
void SetSegmentOverrideColor(std::string segmentID, vtkVector3d overrideColor)
Set segment override color by segment ID.
void SetSegmentOpacity2DOutline(std::string segmentID, double opacity)
Set segment 2D outline opacity by segment ID. Convenience function for python compatibility.
double GetSegmentOpacity3D(std::string segmentID)
bool GetSegmentColor(std::string segmentID, double *color)
Get segment color by segment ID. If overridden then the override color is returned.
SegmentDisplayPropertiesMap SegmentationDisplayProperties
void SetSegmentDisplayProperties(std::string segmentID, SegmentDisplayProperties &properties)
Set segment display properties.
void ClearSegmentDisplayProperties()
Clear segment display properties.
void SetSegmentOpacity2DFill(std::string segmentID, double opacity)
Set segment 2D fill opacity by segment ID. Convenience function for python compatibility.
double GetSegmentOpacity2DFill(std::string segmentID)
std::vector< std::string > GetVisibleSegmentIDs()
Get all visible segment IDs.
const char * GetNodeTagName() override
Get node XML tag name (like Volume, Model)
vtkVector3d GetSegmentOverrideColor(std::string segmentID)
void operator=(const vtkMRMLSegmentationDisplayNode &)
vtkVector3d GetSegmentColor(std::string segmentID)
bool GetSegmentPickable(std::string segmentID)
static vtkMRMLSegmentationDisplayNode * New()
void SetAllSegmentsOpacity2DFill(double opacity, bool changeVisibleSegmentsOnly=false)
void GenerateSegmentColor(double &r, double &g, double &b)
void SetAllSegmentsPickable(bool pickable, bool changeVisibleSegmentsOnly=false)
void GenerateSegmentColor(double color[3], int colorNumber=0)
double GetSegmentOpacity2DOutline(std::string segmentID)
void SetAllSegmentsOpacity2DOutline(double opacity, bool changeVisibleSegmentsOnly=false)
bool GetSegmentDisplayProperties(std::string segmentID, SegmentDisplayProperties &properties)
void GetVisibleSegmentIDs(std::vector< std::string > &segmentIDs)
Get all visible segment IDs.
void SetSegmentColorGeneratorSourceColorNodeID(const char *colorNodeID)
vtkMRMLSegmentationDisplayNode(const vtkMRMLSegmentationDisplayNode &)
void PrintSelf(ostream &os, vtkIndent indent) override
std::string GetDisplayRepresentationName2D()
bool GetSegmentVisibility(std::string segmentID)
void SetAllSegmentsVisibility3D(bool visible, bool changeVisibleSegmentsOnly=false)
void GetVisibleSegmentIDs(vtkStringArray *segmentIDs)
Get all visible segment IDs.
bool GetSegmentVisibility2DFill(std::string segmentID)
void SetAllSegmentsVisibility2DFill(bool visible, bool changeVisibleSegmentsOnly=false)
void GetPolyDataRepresentationNames(std::set< std::string > &representationNames)
Collect representation names that are stored as poly data.
void UnsetSegmentOverrideColor(std::string segmentID)
Unset segment override color (default segment color will be used for display instead).
void SetSegmentVisibility2DFill(std::string segmentID, bool visible)
Set segment 2D fill visibility by segment ID. Convenience function for python compatibility.
vtkMRMLNode * CreateNodeInstance() override
Create instance of the default node. Like New only virtual.
void SetSegmentPickable(std::string segmentID, bool pickable)
Set segment 2D pickability by segment ID. Convenience function for python compatibility.
void SetSegmentOpacity3D(std::string segmentID, double opacity)
Set segment 3D opacity by segment ID. Convenience function for python compatibility.
vtkMRMLCopyContentMacro(vtkMRMLSegmentationDisplayNode)
void SetAllSegmentsVisibility(bool visible)
std::map< std::string, SegmentDisplayProperties > SegmentDisplayPropertiesMap
void UpdateSegmentList(bool removeUnusedDisplayProperties=true)
void ReadXMLAttributes(const char **atts) override
Set node attributes from name/value pairs.
void SetSegmentDisplayPropertiesToDefault(const std::string &segmentId)
Set segment display properties to default.
const char * GetSegmentColorGeneratorSourceColorNodeID()
void GetSegmentIDs(std::vector< std::string > &segmentIDs, bool visibleSegmentsOnly)
Convenience function for getting all segment IDs.
void SetAllSegmentsOpacity(double opacity, bool changeVisibleSegmentsOnly=false)
bool GetSegmentColor(std::string segmentID, double &r, double &g, double &b)
Get segment color by segment ID. If overridden then the override color is returned.
void SetSegmentVisibility(std::string segmentID, bool visible)
Set overall segment visibility by segment ID. Convenience function for python compatibility.
std::string GetDisplayRepresentationName3D()
void SetAllSegmentsOpacity3D(double opacity, bool changeVisibleSegmentsOnly=false)
void SetSegmentOverrideColor(std::string segmentID, double r, double g, double b)
void SetAllSegmentsVisibility2DOutline(bool visible, bool changeVisibleSegmentsOnly=false)
void SetSegmentVisibility2DOutline(std::string segmentID, bool visible)
Set segment 2D outline visibility by segment ID. Convenience function for python compatibility.
~vtkMRMLSegmentationDisplayNode() override
MRML node containing segmentations.
This class encapsulates a segmentation that can contain multiple segments and multiple representation...