Slicer 5.9
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
Loading...
Searching...
No Matches
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
34
35class VTK_SLICER_MARKUPS_MODULE_MRML_EXPORT vtkMRMLMarkupsJsonStorageNode : public vtkMRMLMarkupsStorageNode
36{
37public:
40 void PrintSelf(ostream& os, vtkIndent indent) override;
41
43
45 vtkMRMLMarkupsNode* AddNewMarkupsNodeFromFile(const char* filePath, const char* nodeName = nullptr, int markupIndex = 0);
46
49 const char* GetNodeTagName() override { return "MarkupsJsonStorage"; };
50
52 void ReadXMLAttributes(const char** atts) override;
53
55 void WriteXML(ostream& of, int indent) override;
56
58 void Copy(vtkMRMLNode* node) override;
59
60 bool CanReadInReferenceNode(vtkMRMLNode* refNode) override;
61
64 void GetMarkupsTypesInFile(const char* filePath, std::vector<std::string>& outputMarkupsTypes);
65
66protected:
71
74
77
79 int ReadDataInternal(vtkMRMLNode* refNode) override;
80
82 int WriteDataInternal(vtkMRMLNode* refNode) override;
83
85 VTK_NEWINSTANCE
86 vtkMRMLJsonElement* ReadMarkupsFile(const char* filePath);
87
88 std::string GetMarkupsClassNameFromMarkupsType(std::string markupsType);
89
90 virtual bool UpdateMarkupsNodeFromJsonValue(vtkMRMLMarkupsNode* markupsNode, vtkMRMLJsonElement* markupObject);
92
93 virtual bool ReadControlPoints(vtkMRMLJsonElement* controlPointsArray, int coordinateSystem, vtkMRMLMarkupsNode* markupsNode);
94 virtual bool ReadMeasurements(vtkMRMLJsonElement* measurementsArray, vtkMRMLMarkupsNode* markupsNode);
95
96 virtual bool WriteMarkup(vtkMRMLJsonWriter* writer, vtkMRMLMarkupsNode* markupsNode);
97 virtual bool WriteBasicProperties(vtkMRMLJsonWriter* writer, vtkMRMLMarkupsNode* markupsNode);
98 virtual bool WriteControlPoints(vtkMRMLJsonWriter* writer, vtkMRMLMarkupsNode* markupsNode);
99 virtual bool WriteMeasurements(vtkMRMLJsonWriter* writer, vtkMRMLMarkupsNode* markupsNode);
100 virtual bool WriteDisplayProperties(vtkMRMLJsonWriter* writer, vtkMRMLMarkupsDisplayNode* markupsDisplayNode);
101
103};
104
105#endif
Represents a json object or list.
Writes properties into a JSON stream.
const char * GetNodeTagName() override
Get node XML tag name (like Storage, Model)
virtual bool WriteMarkup(vtkMRMLJsonWriter *writer, vtkMRMLMarkupsNode *markupsNode)
~vtkMRMLMarkupsJsonStorageNode() override
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.
virtual bool UpdateMarkupsNodeFromJsonValue(vtkMRMLMarkupsNode *markupsNode, vtkMRMLJsonElement *markupObject)
virtual bool ReadMeasurements(vtkMRMLJsonElement *measurementsArray, vtkMRMLMarkupsNode *markupsNode)
vtkMRMLNode * CreateNodeInstance() override
Create instance of the default node. Like New only virtual.
void operator=(const vtkMRMLMarkupsJsonStorageNode &)
void Copy(vtkMRMLNode *node) override
Copy the node's attributes to this object.
std::string GetMarkupsClassNameFromMarkupsType(std::string markupsType)
virtual bool WriteMeasurements(vtkMRMLJsonWriter *writer, vtkMRMLMarkupsNode *markupsNode)
void PrintSelf(ostream &os, vtkIndent indent) override
virtual bool ReadControlPoints(vtkMRMLJsonElement *controlPointsArray, int coordinateSystem, vtkMRMLMarkupsNode *markupsNode)
virtual bool UpdateMarkupsDisplayNodeFromJsonValue(vtkMRMLMarkupsDisplayNode *displayNode, vtkMRMLJsonElement *markupObject)
virtual bool WriteDisplayProperties(vtkMRMLJsonWriter *writer, vtkMRMLMarkupsDisplayNode *markupsDisplayNode)
void WriteXML(ostream &of, int indent) override
Write this node's information to a MRML file in XML format.
vtkMRMLMarkupsJsonStorageNode(const vtkMRMLMarkupsJsonStorageNode &)
bool CanReadInReferenceNode(vtkMRMLNode *refNode) override
std::string GetCoordinateUnitsFromSceneAsString(vtkMRMLMarkupsNode *markupsNode)
virtual bool WriteBasicProperties(vtkMRMLJsonWriter *writer, vtkMRMLMarkupsNode *markupsNode)
int ReadDataInternal(vtkMRMLNode *refNode) override
Read data and set it in the referenced node.
VTK_NEWINSTANCE vtkMRMLJsonElement * ReadMarkupsFile(const char *filePath)
Only in C++: The caller must take ownership of the returned object.
virtual bool WriteControlPoints(vtkMRMLJsonWriter *writer, vtkMRMLMarkupsNode *markupsNode)