VTK
vtkMINCImageAttributes.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkMINCImageAttributes.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
15 /*=========================================================================
16 
17 Copyright (c) 2006 Atamai, Inc.
18 
19 Use, modification and redistribution of the software, in source or
20 binary forms, are permitted provided that the following terms and
21 conditions are met:
22 
23 1) Redistribution of the source code, in verbatim or modified
24  form, must retain the above copyright notice, this license,
25  the following disclaimer, and any notices that refer to this
26  license and/or the following disclaimer.
27 
28 2) Redistribution in binary form must include the above copyright
29  notice, a copy of this license and the following disclaimer
30  in the documentation or with other materials provided with the
31  distribution.
32 
33 3) Modified copies of the source code must be clearly marked as such,
34  and must not be misrepresented as verbatim copies of the source code.
35 
36 THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE SOFTWARE "AS IS"
37 WITHOUT EXPRESSED OR IMPLIED WARRANTY INCLUDING, BUT NOT LIMITED TO,
38 THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
39 PURPOSE. IN NO EVENT SHALL ANY COPYRIGHT HOLDER OR OTHER PARTY WHO MAY
40 MODIFY AND/OR REDISTRIBUTE THE SOFTWARE UNDER THE TERMS OF THIS LICENSE
41 BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL OR CONSEQUENTIAL DAMAGES
42 (INCLUDING, BUT NOT LIMITED TO, LOSS OF DATA OR DATA BECOMING INACCURATE
43 OR LOSS OF PROFIT OR BUSINESS INTERRUPTION) ARISING IN ANY WAY OUT OF
44 THE USE OR INABILITY TO USE THE SOFTWARE, EVEN IF ADVISED OF THE
45 POSSIBILITY OF SUCH DAMAGES.
46 
47 =========================================================================*/
70 #ifndef vtkMINCImageAttributes_h
71 #define vtkMINCImageAttributes_h
72 
73 #include "vtkIOMINCModule.h" // For export macro
74 #include "vtkObject.h"
75 
76 class vtkDataArray;
77 class vtkStringArray;
78 class vtkIdTypeArray;
79 class vtkDoubleArray;
80 class vtkMatrix4x4;
81 
82 // A special class that holds the attributes
83 class vtkMINCImageAttributeMap;
84 
86 {
87 public:
89 
90  static vtkMINCImageAttributes *New();
91  virtual void PrintSelf(ostream& os, vtkIndent indent);
92 
94  virtual void Reset();
95 
97 
100  vtkSetStringMacro(Name);
101  vtkGetStringMacro(Name);
103 
105 
109  vtkSetMacro(DataType, int);
110  vtkGetMacro(DataType, int);
112 
114 
118  virtual void AddDimension(const char *dimension) {
119  this->AddDimension(dimension, 0); };
120  virtual void AddDimension(const char *dimension, vtkIdType length);
122 
124 
129  return this->DimensionNames; };
131 
133 
137  return this->DimensionLengths; };
139 
141 
143  return this->VariableNames; };
145 
148  virtual vtkStringArray *GetAttributeNames(const char *variable);
149 
151 
154  virtual void SetImageMin(vtkDoubleArray *imageMin);
155  virtual void SetImageMax(vtkDoubleArray *imageMax);
156  virtual vtkDoubleArray *GetImageMin() { return this->ImageMin; };
157  virtual vtkDoubleArray *GetImageMax() { return this->ImageMax; };
159 
161 
162  vtkGetMacro(NumberOfImageMinMaxDimensions, int);
163  vtkSetMacro(NumberOfImageMinMaxDimensions, int);
165 
167  virtual int HasAttribute(const char *variable, const char *attribute);
168 
170 
172  virtual void SetAttributeValueAsArray(const char *variable,
173  const char *attribute,
174  vtkDataArray *array);
175  virtual vtkDataArray *GetAttributeValueAsArray(const char *variable,
176  const char *attribute);
178 
180 
183  virtual void SetAttributeValueAsString(const char *variable,
184  const char *attribute,
185  const char *value);
186  virtual const char *GetAttributeValueAsString(const char *variable,
187  const char *attribute);
189 
191 
194  virtual void SetAttributeValueAsInt(const char *variable,
195  const char *attribute,
196  int value);
197  virtual int GetAttributeValueAsInt(const char *variable,
198  const char *attribute);
200 
202 
205  virtual void SetAttributeValueAsDouble(const char *variable,
206  const char *attribute,
207  double value);
208  virtual double GetAttributeValueAsDouble(const char *variable,
209  const char *attribute);
211 
212 
214 
221  virtual int ValidateAttribute(const char *varname,
222  const char *attname,
223  vtkDataArray *array);
225 
227 
229  vtkSetMacro(ValidateAttributes, int);
230  vtkBooleanMacro(ValidateAttributes, int);
231  vtkGetMacro(ValidateAttributes, int);
233 
240  virtual void ShallowCopy(vtkMINCImageAttributes *source);
241 
244  virtual void FindValidRange(double range[2]);
245 
248  virtual void FindImageRange(double range[2]);
249 
251 
253  virtual void PrintFileHeader();
254  virtual void PrintFileHeader(ostream &os);
256 
257 protected:
260 
261  const char *ConvertDataArrayToString(vtkDataArray *array);
262 
263  virtual int ValidateGlobalAttribute(const char *attrib,
264  vtkDataArray *array);
265  virtual int ValidateGeneralAttribute(const char *varname,
266  const char *attname,
267  vtkDataArray *array);
268  virtual int ValidateDimensionAttribute(const char *varname,
269  const char *attname,
270  vtkDataArray *array);
271  virtual int ValidateImageAttribute(const char *varname,
272  const char *attname,
273  vtkDataArray *array);
274  virtual int ValidateImageMinMaxAttribute(const char *varname,
275  const char *attname,
276  vtkDataArray *array);
277  virtual int ValidatePatientAttribute(const char *varname,
278  const char *attname,
279  vtkDataArray *array);
280  virtual int ValidateStudyAttribute(const char *varname,
281  const char *attname,
282  vtkDataArray *array);
283  virtual int ValidateAcquisitionAttribute(const char *varname,
284  const char *attname,
285  vtkDataArray *array);
286 
289 
291  vtkMINCImageAttributeMap *AttributeNames;
292  vtkMINCImageAttributeMap *AttributeValues;
293 
295 
299 
300  int DataType;
301  char *Name;
302 
304 
305 private:
306  vtkMINCImageAttributes(const vtkMINCImageAttributes&); // Not implemented
307  void operator=(const vtkMINCImageAttributes&); // Not implemented
308 
309 };
310 
311 #endif /* vtkMINCImageAttributes_h */
vtkMINCImageAttributeMap * AttributeValues
abstract base class for most VTK objects
Definition: vtkObject.h:61
represent and manipulate 4x4 transformation matrices
Definition: vtkMatrix4x4.h:38
virtual vtkDoubleArray * GetImageMax()
a vtkAbstractArray subclass for strings
vtkMINCImageAttributeMap * AttributeNames
dynamic, self-adjusting array of vtkIdType
int vtkIdType
Definition: vtkType.h:275
virtual vtkDoubleArray * GetImageMin()
virtual vtkStringArray * GetDimensionNames()
dynamic, self-adjusting array of double
#define VTKIOMINC_EXPORT
virtual vtkIdTypeArray * GetDimensionLengths()
A container for a MINC image header.
virtual void PrintSelf(ostream &os, vtkIndent indent)
virtual void AddDimension(const char *dimension)
a simple class to control print indentation
Definition: vtkIndent.h:38
virtual vtkStringArray * GetVariableNames()
abstract superclass for arrays of numeric data
Definition: vtkDataArray.h:54
boost::graph_traits< vtkGraph * >::vertex_descriptor source(boost::graph_traits< vtkGraph * >::edge_descriptor e, vtkGraph *)
static vtkObject * New()