00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00025 #ifndef __itkNiftiImageIO_h
00026 #define __itkNiftiImageIO_h
00027
00028 #ifdef _MSC_VER
00029 #pragma warning ( disable : 4786 )
00030 #endif
00031
00032 #include <fstream>
00033 #include "itkImageIOBase.h"
00034 #include <nifti1_io.h>
00035
00036 namespace itk
00037 {
00044 class ITK_EXPORT NiftiImageIO : public ImageIOBase
00045 {
00046 public:
00048 typedef NiftiImageIO Self;
00049 typedef ImageIOBase Superclass;
00050 typedef SmartPointer<Self> Pointer;
00051
00053 itkNewMacro(Self);
00054
00056 itkTypeMacro(NiftiImageIO, Superclass);
00057
00058
00059
00066 virtual bool CanReadFile(const char* FileNameToRead) ;
00067
00069 virtual void ReadImageInformation();
00070
00072 virtual void Read(void* buffer);
00073
00074
00075
00082 virtual bool CanWriteFile(const char * FileNameToWrite);
00083
00085 virtual void WriteImageInformation();
00086
00089 virtual void Write(const void* buffer);
00090
00091
00092 protected:
00093 NiftiImageIO();
00094 ~NiftiImageIO();
00095 void PrintSelf(std::ostream& os, Indent indent) const;
00096 private:
00097 void DefineHeaderObjectDataType();
00113 typedef enum {
00114 ITK_ANALYZE_ORIENTATION_RPI_TRANSVERSE=0,
00115 ITK_ANALYZE_ORIENTATION_RIP_CORONAL =1,
00116 ITK_ANALYZE_ORIENTATION_PIR_SAGITTAL =2,
00117 ITK_ANALYZE_ORIENTATION_RAI_TRANSVERSE_FLIPPED=3,
00118 ITK_ANALYZE_ORIENTATION_RSP_CORONAL_FLIPPED=4,
00119 ITK_ANALYZE_ORIENTATION_PIL_SAGITTAL_FLIPPED=5
00120 } ValidNiftiOrientationFlags;
00121 nifti_image * m_NiftiImage;
00122 double m_RescaleSlope;
00123 double m_RescaleIntercept;
00124
00125 NiftiImageIO(const Self&);
00126 void operator=(const Self&);
00127 };
00128 }
00129
00130 #endif // __itkNiftiImageIO_h