Slicer 5.9
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
Loading...
Searching...
No Matches
vtkMRMLVolumePropertyJsonStorageNode.h
Go to the documentation of this file.
1/*==============================================================================
2
3 Copyright (c) Laboratory for Percutaneous Surgery (PerkLab)
4 Queen's University, Kingston, ON, Canada. All Rights Reserved.
5
6 See COPYRIGHT.txt
7 or http://www.slicer.org/copyright/copyright.txt for details.
8
9 Unless required by applicable law or agreed to in writing, software
10 distributed under the License is distributed on an "AS IS" BASIS,
11 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 See the License for the specific language governing permissions and
13 limitations under the License.
14
15 This file was originally developed by Kyle Sunderland, PerkLab, Queen's University
16 and was supported in part through NIH grant R01 HL153166.
17
18==============================================================================*/
22
23#ifndef __vtkMRMLVolumePropertyJsonStorageNode_h
24#define __vtkMRMLVolumePropertyJsonStorageNode_h
25
26// VolumeRendering includes
27#include "vtkSlicerVolumeRenderingModuleMRMLExport.h"
28
29// MRML includes
30#include "vtkMRMLStorageNode.h"
31
32class vtkContourValues;
33class vtkDataObject;
34class vtkImageData;
38class vtkPiecewiseFunction;
39class vtkVolumeProperty;
40
41class VTK_SLICER_VOLUMERENDERING_MODULE_MRML_EXPORT vtkMRMLVolumePropertyJsonStorageNode : public vtkMRMLStorageNode
42{
43public:
46 void PrintSelf(ostream& os, vtkIndent indent) override;
47
49
52 const char* GetNodeTagName() override { return "VolumePropertyJsonStorage"; }
53
55 bool CanReadInReferenceNode(vtkMRMLNode* refNode) override;
56
57 int GetNumberOfVolumePropertiesInFile(const char* filePath);
58 vtkMRMLVolumePropertyNode* AddNewVolumePropertyNodeFromFile(const char* filePath, const char* nodeName = nullptr, int vpIndex = 0);
59
60protected:
65
68
71
73 int ReadDataInternal(vtkMRMLNode* refNode) override;
74
76 int WriteDataInternal(vtkMRMLNode* refNode) override;
77
78 static std::string GetInterpolationTypeAsString(int interpolationType);
79 static int GetInterpolationTypeFromString(const std::string& interpolationTypeString);
80
82 bool WriteVolumeProperty(vtkMRMLJsonWriter* writer, vtkVolumeProperty* volumeProperty, int numberOfComponents = 1);
83 bool WriteContourValues(vtkMRMLJsonWriter* writer, const char* name, vtkContourValues* contourValues);
84 bool WriteTransferFunction(vtkMRMLJsonWriter* writer, const char* name, vtkObject* transferFunction);
85
87 bool ReadTransferFunction(vtkObject* transferFunction, vtkMRMLJsonElement* transferFunctionElement);
88};
89
90#endif
Represents a json object or list.
Writes properties into a JSON stream.
bool ReadVolumePropertyNode(vtkMRMLVolumePropertyNode *vpNode, vtkMRMLJsonElement *volumePropertyElement)
bool ReadTransferFunction(vtkObject *transferFunction, vtkMRMLJsonElement *transferFunctionElement)
bool WriteContourValues(vtkMRMLJsonWriter *writer, const char *name, vtkContourValues *contourValues)
void operator=(const vtkMRMLVolumePropertyJsonStorageNode &)
static vtkMRMLVolumePropertyJsonStorageNode * New()
const char * GetNodeTagName() override
Get node XML tag name (like Storage, Transform)
void PrintSelf(ostream &os, vtkIndent indent) override
static int GetInterpolationTypeFromString(const std::string &interpolationTypeString)
bool CanReadInReferenceNode(vtkMRMLNode *refNode) override
Return true if the node can be read in.
void InitializeSupportedWriteFileTypes() override
Initialize all the supported write file types.
static std::string GetInterpolationTypeAsString(int interpolationType)
bool WriteVolumeProperty(vtkMRMLJsonWriter *writer, vtkVolumeProperty *volumeProperty, int numberOfComponents=1)
void InitializeSupportedReadFileTypes() override
Initialize all the supported read file types.
vtkMRMLNode * CreateNodeInstance() override
Create instance of the default node. Like New only virtual.
bool WriteVolumePropertyNode(vtkMRMLJsonWriter *writer, vtkMRMLVolumePropertyNode *volumePropertyNode)
int WriteDataInternal(vtkMRMLNode *refNode) override
Write data from a referenced node.
vtkMRMLVolumePropertyJsonStorageNode(const vtkMRMLVolumePropertyJsonStorageNode &)
int ReadDataInternal(vtkMRMLNode *refNode) override
Read data and set it in the referenced node.
int GetNumberOfVolumePropertiesInFile(const char *filePath)
vtkMRMLVolumePropertyNode * AddNewVolumePropertyNodeFromFile(const char *filePath, const char *nodeName=nullptr, int vpIndex=0)
bool WriteTransferFunction(vtkMRMLJsonWriter *writer, const char *name, vtkObject *transferFunction)
vtkMRMLVolumePropertyNode contains the transfer functions (scalar opacity, color and gradient opacity...