23#ifndef __vtkMRMLSegmentationDisplayNode_h
24#define __vtkMRMLSegmentationDisplayNode_h
51 double OverrideColor[3];
55 bool Visible2DFill{
true};
56 bool Visible2DOutline{
true};
58 double Opacity3D{1.0};
59 double Opacity2DFill{1.0};
60 double Opacity2DOutline{1.0};
67 OverrideColor[0] = SEGMENT_COLOR_NO_OVERRIDE;
68 OverrideColor[1] = SEGMENT_COLOR_NO_OVERRIDE;
69 OverrideColor[2] = SEGMENT_COLOR_NO_OVERRIDE;
81 void PrintSelf(ostream& os, vtkIndent indent)
override;
89 void WriteXML(ostream& of,
int indent)
override;
101 vtkGetStringMacro(PreferredDisplayRepresentationName2D);
103 vtkSetStringMacro(PreferredDisplayRepresentationName2D);
105 vtkGetStringMacro(PreferredDisplayRepresentationName3D);
107 vtkSetStringMacro(PreferredDisplayRepresentationName3D);
110 vtkGetMacro(Visibility2DFill,
bool);
111 vtkSetMacro(Visibility2DFill,
bool);
112 vtkBooleanMacro(Visibility2DFill,
bool);
114 vtkGetMacro(Visibility2DOutline,
bool);
115 vtkSetMacro(Visibility2DOutline,
bool);
116 vtkBooleanMacro(Visibility2DOutline,
bool);
119 vtkGetMacro(Opacity3D,
double);
120 vtkSetMacro(Opacity3D,
double);
122 vtkGetMacro(Opacity2DFill,
double);
123 vtkSetMacro(Opacity2DFill,
double);
125 vtkGetMacro(Opacity2DOutline,
double);
126 vtkSetMacro(Opacity2DOutline,
double);
281 void GetSegmentIDs(std::vector<std::string>& segmentIDs,
bool visibleSegmentsOnly);
299 char* PreferredDisplayRepresentationName2D{
nullptr};
304 char* PreferredDisplayRepresentationName3D{
nullptr};
312 unsigned int NumberOfGeneratedColors{0};
315 vtkMTimeType SegmentListUpdateTime{0};
321 bool Visibility2DFill{
true};
325 bool Visibility2DOutline{
true};
328 double Opacity3D{1.0};
330 double Opacity2DFill{0.5};
332 double Opacity2DOutline{1.0};
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.
static const double SEGMENT_COLOR_NO_OVERRIDE
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.
bool CalculateAutoOpacitiesForSegments()
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)
vtkMRMLSegmentationDisplayNode()
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...
Display properties per segment.
SegmentDisplayProperties()