9#ifndef __vtkMRMLAnnotationDisplayNode_h
10#define __vtkMRMLAnnotationDisplayNode_h
16#include "vtkSlicerAnnotationsModuleMRMLExport.h"
18#define vtkSetAndPropagateVector3Macro(name, type) \
19 virtual void SetAndPropagateSuper##name(type _arg1, type _arg2, type _arg3) \
21 vtkDebugMacro(<< this->GetClassName() << " (" << this << "): setting Super" << #name " to (" << _arg1 << "," << _arg2 << "," << _arg3 << ")"); \
22 if ((this->Super##name[0] != _arg1) || (this->Super##name[1] != _arg2) || (this->Super##name[2] != _arg3)) \
24 this->name[0] = _arg1; \
25 this->name[1] = _arg2; \
26 this->name[2] = _arg3; \
27 this->Super##name[0] = _arg1; \
28 this->Super##name[1] = _arg2; \
29 this->Super##name[2] = _arg3; \
30 vtkMRMLDisplayableNode* displayableNode = this->GetDisplayableNode(); \
31 if (!displayableNode) \
35 for (int i = 0; i < displayableNode->GetNumberOfDisplayNodes(); i++) \
37 vtkMRMLDisplayNode* displayNode = displayableNode->GetNthDisplayNode(i); \
38 if (!displayNode || displayNode == this) \
42 displayNode->Set##name(this->Super##name); \
47 virtual void SetAndPropagateSuper##name(type _arg[3]) \
49 this->SetAndPropagateSuper##name(_arg[0], _arg[1], _arg[2]); \
52#define vtkSetAndPropagateMacro(name, type) \
53 virtual void SetAndPropagateSuper##name(type _arg) \
55 vtkDebugMacro(<< this->GetClassName() << " (" << this << "): setting Super" << #name " to (" << _arg << ")"); \
56 if (this->Super##name != _arg) \
59 this->Super##name = _arg; \
60 vtkMRMLDisplayableNode* displayableNode = this->GetDisplayableNode(); \
61 if (!displayableNode) \
65 for (int i = 0; i < displayableNode->GetNumberOfDisplayNodes(); i++) \
67 vtkMRMLDisplayNode* displayNode = displayableNode->GetNthDisplayNode(i); \
68 if (!displayNode || displayNode == this) \
72 displayNode->Set##name(this->Super##name); \
83 void PrintSelf(ostream& os, vtkIndent indent)
override;
97 void WriteXML(ostream& of,
int indent)
override;
170 inline void SliceProjectionOn();
173 inline void SliceProjectionOff();
vtkSetAndPropagateMacro(SelectedAmbient, double)
vtkSetAndPropagateVector3Macro(Color, double)
vtkSetAndPropagateMacro(Specular, double)
static vtkMRMLAnnotationDisplayNode * New()
vtkSetAndPropagateMacro(Diffuse, double)
void ProcessMRMLEvents(vtkObject *, unsigned long, void *) override
Propagate events generated in mrml.
const char * GetNodeTagName() override
vtkSetAndPropagateMacro(Ambient, double)
vtkMRMLAnnotationDisplayNode * GetBackup()
Returns the associated backup of this node.
vtkMRMLAnnotationDisplayNode()
virtual int GetSliceProjection()
vtkSetAndPropagateVector3Macro(SelectedColor, double)
void WriteXML(ostream &of, int indent) override
~vtkMRMLAnnotationDisplayNode() override
void SliceProjectionOff()
Set SliceProjection to Off.
vtkSetAndPropagateMacro(Opacity, double)
vtkSetAndPropagateMacro(SelectedSpecular, double)
vtkSetAndPropagateMacro(Power, double)
void PrintSelf(ostream &os, vtkIndent indent) override
double SuperSelectedColor[3]
void SliceProjectionOn()
Set SliceProjection to On.
void ReadXMLAttributes(const char **atts) override
void operator=(const vtkMRMLAnnotationDisplayNode &)
virtual void RestoreBackup()
void Copy(vtkMRMLNode *node) override
Copy node contents from another node of the same type. Does not copy node ID and Scene....
double SuperSelectedAmbient
vtkMRMLAnnotationDisplayNode * m_Backup
vtkMRMLAnnotationDisplayNode(const vtkMRMLAnnotationDisplayNode &)
void UpdateScene(vtkMRMLScene *scene) override
virtual void SetSliceProjection(int)
double SuperSelectedSpecular
virtual void CreateBackup()
Creates a backup of the current MRML state of this node and keeps a reference.
vtkMRMLNode * CreateNodeInstance() override
Create instance of the default node. Like New only virtual.
vtkMRMLModelDisplayNode()
friend class vtkMRMLScene