ITK  5.0.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:
65  ITK_DISALLOW_COPY_AND_ASSIGN(StimulateImageIO);
66 
71 
73  itkNewMacro(Self);
74 
76  itkTypeMacro(StimulateImageIO, Superclass);
77 
78  /*-------- This part of the interface deals with reading data. ------ */
79 
82  bool CanReadFile(const char *) override;
83 
85  void ReadImageInformation() override;
86 
88  void Read(void *buffer) override;
89 
90  /*-------- This part of the interfaces deals with writing data. ----- */
91 
94  bool CanWriteFile(const char *) override;
95 
98  void WriteImageInformation() override {}
99 
102  void Write(const void *buffer) override;
103 
110  itkGetVectorMacro(DisplayRange, const float, 2);
111  const float & GetHighDisplayValue()
112  {
113  return m_DisplayRange[1];
114  }
115  const float & GetLowDisplayValue()
116  {
117  return m_DisplayRange[1];
118  }
120 
121 protected:
123  ~StimulateImageIO() override;
124  void PrintSelf(std::ostream & os, Indent indent) const override;
125 
126  void InternalReadImageInformation(std::ifstream & file);
127 
128 private:
129  std::string m_DataFileName;
130  char m_SdtOrient[256];
131  float m_DisplayRange[2];
132  char m_FidName[256];
133 
134 };
135 } // end namespace itk
136 
137 #endif // itkStimulateImageIO_h
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()
void WriteImageInformation() override
Control indentation during Print() invocation.
Definition: itkIndent.h:49
Base class for most ITK classes.
Definition: itkObject.h:60
const float & GetHighDisplayValue()