ITK  4.9.0
Insight Segmentation and Registration Toolkit
itkStimulateImageIO.h
Go to the documentation of this file.
1 /*=========================================================================
2  *
3  * Copyright Insight Software Consortium
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0.txt
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  *=========================================================================*/
18 /*=========================================================================
19  *
20  * Portions of this file are subject to the VTK Toolkit Version 3 copyright.
21  *
22  * Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
23  *
24  * For complete copyright, license and disclaimer of warranty information
25  * please refer to the NOTICE file at the top of the ITK source tree.
26  *
27  *=========================================================================*/
28 #ifndef itkStimulateImageIO_h
29 #define itkStimulateImageIO_h
30 #include "ITKIOStimulateExport.h"
31 
32 
33 #include <fstream>
34 #include "itkImageIOBase.h"
35 
36 namespace itk
37 {
62 class ITKIOStimulate_EXPORT StimulateImageIO:public ImageIOBase
63 {
64 public:
69 
71  itkNewMacro(Self);
72 
74  itkTypeMacro(StimulateImageIO, Superclass);
75 
76  /*-------- This part of the interface deals with reading data. ------ */
77 
80  virtual bool CanReadFile(const char *) ITK_OVERRIDE;
81 
83  virtual void ReadImageInformation() ITK_OVERRIDE;
84 
86  virtual void Read(void *buffer) ITK_OVERRIDE;
87 
88  /*-------- This part of the interfaces deals with writing data. ----- */
89 
92  virtual bool CanWriteFile(const char *) ITK_OVERRIDE;
93 
96  virtual void WriteImageInformation() ITK_OVERRIDE {}
97 
100  virtual void Write(const void *buffer) ITK_OVERRIDE;
101 
108  itkGetVectorMacro(DisplayRange, const float, 2);
109  const float & GetHighDisplayValue()
110  {
111  return m_DisplayRange[1];
112  }
113  const float & GetLowDisplayValue()
114  {
115  return m_DisplayRange[1];
116  }
118 
119 protected:
121  ~StimulateImageIO();
122  virtual void PrintSelf(std::ostream & os, Indent indent) const ITK_OVERRIDE;
123 
124  void InternalReadImageInformation(std::ifstream & file);
125 
126 private:
127  std::string m_DataFileName;
128  char m_SdtOrient[256];
129  float m_DisplayRange[2];
130  char m_FidName[256];
131 
132  StimulateImageIO(const Self &) ITK_DELETE_FUNCTION;
133  void operator=(const Self &) ITK_DELETE_FUNCTION;
134 };
135 } // end namespace itk
136 
137 #endif // itkStimulateImageIO_h
SmartPointer< Self > Pointer
Light weight base class for most itk classes.
ImageIO class for reading SDT/SPR (Stimulate) images This format is similar to a MetaImageIO file: Th...
Abstract superclass defines image IO interface.
const float & GetLowDisplayValue()
Control indentation during Print() invocation.
Definition: itkIndent.h:49
Base class for most ITK classes.
Definition: itkObject.h:57
const float & GetHighDisplayValue()