Slicer  5.1
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
vtkMRMLMarkupsFiducialStorageNode.h
Go to the documentation of this file.
1 /*==============================================================================
2 
3  Program: 3D Slicer
4 
5  Portions (c) Copyright Brigham and Women's Hospital (BWH) All Rights Reserved.
6 
7  See COPYRIGHT.txt
8  or http://www.slicer.org/copyright/copyright.txt for details.
9 
10  Unless required by applicable law or agreed to in writing, software
11  distributed under the License is distributed on an "AS IS" BASIS,
12  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  See the License for the specific language governing permissions and
14  limitations under the License.
15 
16 ==============================================================================*/
17 
24 
25 #ifndef __vtkMRMLMarkupsFiducialStorageNode_h
26 #define __vtkMRMLMarkupsFiducialStorageNode_h
27 
28 // Markups includes
29 #include "vtkSlicerMarkupsModuleMRMLExport.h"
31 
32 class vtkMRMLMarkupsNode;
33 
35 class VTK_SLICER_MARKUPS_MODULE_MRML_EXPORT vtkMRMLMarkupsFiducialStorageNode : public vtkMRMLMarkupsStorageNode
36 {
37 public:
40  void PrintSelf(ostream& os, vtkIndent indent) override;
41 
42  vtkMRMLNode* CreateNodeInstance() override;
43 
46  const char* GetNodeTagName() override {return "MarkupsFiducialStorage";};
47 
49  void ReadXMLAttributes( const char** atts) override;
50 
52  void WriteXML(ostream& of, int indent) override;
53 
55  void Copy(vtkMRMLNode *node) override;
56 
57  bool CanReadInReferenceNode(vtkMRMLNode *refNode) override;
58 
59  virtual bool SetPointFromString(vtkMRMLMarkupsNode *markupsNode, int pointIndex, const char* str);
60 
61  virtual std::string GetPointAsString(vtkMRMLMarkupsNode *markupsNode, int pointIndex);
62 
66  vtkSetMacro(FieldDelimiterCharacters, std::string);
67  vtkGetMacro(FieldDelimiterCharacters, std::string);
68 
74  std::string ConvertStringToStorageFormat(std::string input);
75  std::string ConvertStringFromStorageFormat(std::string input);
76 
78  static int GetMaximumLineLength() { return 1024; }
79 
80 protected:
85 
87  void InitializeSupportedReadFileTypes() override;
88 
90  void InitializeSupportedWriteFileTypes() override;
91 
93  int ReadDataInternal(vtkMRMLNode *refNode) override;
94 
103  int WriteDataInternal(vtkMRMLNode *refNode) override;
104 
106 };
107 
108 #endif
vtkMRMLNode * CreateNodeInstance() override=0
Create instance of the default node. Like New only virtual.
bool CanReadInReferenceNode(vtkMRMLNode *refNode) override
virtual int ReadDataInternal(vtkMRMLNode *refNode)
void ReadXMLAttributes(const char **atts) override
Read node attributes from XML file.
void Copy(vtkMRMLNode *node) override
Copy the node's attributes to this object.
virtual void InitializeSupportedReadFileTypes()
const char * GetNodeTagName() override
Get node XML tag name (like Storage, Model)
virtual void InitializeSupportedWriteFileTypes()
void WriteXML(ostream &of, int indent) override
Write this node's information to a MRML file in XML format.
static int GetMaximumLineLength()
Buffer size for parsing files during read.
virtual int WriteDataInternal(vtkMRMLNode *refNode)
Abstract Superclass for all specific types of MRML nodes.
Definition: vtkMRMLNode.h:167
void PrintSelf(ostream &os, vtkIndent indent) override
void operator=(const vtkMRMLMarkupsStorageNode &)