Slicer 5.9
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
vtkMRMLMarkupsJsonStorageNode.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
22
23#ifndef __vtkMRMLMarkupsJsonStorageNode_h
24#define __vtkMRMLMarkupsJsonStorageNode_h
25
26// Markups includes
27#include "vtkSlicerMarkupsModuleMRMLExport.h"
29
30
35
36class VTK_SLICER_MARKUPS_MODULE_MRML_EXPORT vtkMRMLMarkupsJsonStorageNode : public vtkMRMLMarkupsStorageNode
37{
38public:
41 void PrintSelf(ostream& os, vtkIndent indent) override;
42
44
46 vtkMRMLMarkupsNode* AddNewMarkupsNodeFromFile(const char* filePath, const char* nodeName=nullptr, int markupIndex=0);
47
50 const char* GetNodeTagName() override {return "MarkupsJsonStorage";};
51
53 void ReadXMLAttributes( const char** atts) override;
54
56 void WriteXML(ostream& of, int indent) override;
57
59 void Copy(vtkMRMLNode *node) override;
60
61 bool CanReadInReferenceNode(vtkMRMLNode *refNode) override;
62
65 void GetMarkupsTypesInFile(const char* filePath, std::vector<std::string>& outputMarkupsTypes);
66
67protected:
72
75
78
80 int ReadDataInternal(vtkMRMLNode *refNode) override;
81
83 int WriteDataInternal(vtkMRMLNode *refNode) override;
84
86 VTK_NEWINSTANCE
88
89 std::string GetMarkupsClassNameFromMarkupsType(std::string markupsType);
90
93
94 virtual bool ReadControlPoints(vtkMRMLMarkupsJsonElement* controlPointsArray, int coordinateSystem, vtkMRMLMarkupsNode* markupsNode);
95 virtual bool ReadMeasurements(vtkMRMLMarkupsJsonElement* measurementsArray, vtkMRMLMarkupsNode* markupsNode);
96
97 virtual bool WriteMarkup(vtkMRMLMarkupsJsonWriter* writer, vtkMRMLMarkupsNode* markupsNode);
102
104};
105
106#endif
Represents a json object or list.
const char * GetNodeTagName() override
Get node XML tag name (like Storage, Model)
virtual bool ReadMeasurements(vtkMRMLMarkupsJsonElement *measurementsArray, vtkMRMLMarkupsNode *markupsNode)
virtual bool UpdateMarkupsNodeFromJsonValue(vtkMRMLMarkupsNode *markupsNode, vtkMRMLMarkupsJsonElement *markupObject)
~vtkMRMLMarkupsJsonStorageNode() override
virtual bool WriteMarkup(vtkMRMLMarkupsJsonWriter *writer, vtkMRMLMarkupsNode *markupsNode)
virtual bool WriteMeasurements(vtkMRMLMarkupsJsonWriter *writer, vtkMRMLMarkupsNode *markupsNode)
void InitializeSupportedReadFileTypes() override
Initialize all the supported write file types.
static vtkMRMLMarkupsJsonStorageNode * New()
void GetMarkupsTypesInFile(const char *filePath, std::vector< std::string > &outputMarkupsTypes)
vtkMRMLMarkupsNode * AddNewMarkupsNodeFromFile(const char *filePath, const char *nodeName=nullptr, int markupIndex=0)
Read a markups node from a file.
int WriteDataInternal(vtkMRMLNode *refNode) override
Write data from a referenced node.
void InitializeSupportedWriteFileTypes() override
Initialize all the supported write file types.
void ReadXMLAttributes(const char **atts) override
Read node attributes from XML file.
vtkMRMLNode * CreateNodeInstance() override
Create instance of the default node. Like New only virtual.
virtual bool WriteControlPoints(vtkMRMLMarkupsJsonWriter *writer, vtkMRMLMarkupsNode *markupsNode)
void operator=(const vtkMRMLMarkupsJsonStorageNode &)
void Copy(vtkMRMLNode *node) override
Copy the node's attributes to this object.
std::string GetMarkupsClassNameFromMarkupsType(std::string markupsType)
void PrintSelf(ostream &os, vtkIndent indent) override
void WriteXML(ostream &of, int indent) override
Write this node's information to a MRML file in XML format.
virtual bool UpdateMarkupsDisplayNodeFromJsonValue(vtkMRMLMarkupsDisplayNode *displayNode, vtkMRMLMarkupsJsonElement *markupObject)
virtual bool WriteDisplayProperties(vtkMRMLMarkupsJsonWriter *writer, vtkMRMLMarkupsDisplayNode *markupsDisplayNode)
vtkMRMLMarkupsJsonStorageNode(const vtkMRMLMarkupsJsonStorageNode &)
bool CanReadInReferenceNode(vtkMRMLNode *refNode) override
virtual bool ReadControlPoints(vtkMRMLMarkupsJsonElement *controlPointsArray, int coordinateSystem, vtkMRMLMarkupsNode *markupsNode)
std::string GetCoordinateUnitsFromSceneAsString(vtkMRMLMarkupsNode *markupsNode)
VTK_NEWINSTANCE vtkMRMLMarkupsJsonElement * ReadMarkupsFile(const char *filePath)
Only in C++: The caller must take ownership of the returned object.
virtual bool WriteBasicProperties(vtkMRMLMarkupsJsonWriter *writer, vtkMRMLMarkupsNode *markupsNode)
int ReadDataInternal(vtkMRMLNode *refNode) override
Read data and set it in the referenced node.
Writes properties into a JSON file.