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 {
00038
00047 class ITK_EXPORT NiftiImageIO : public ImageIOBase
00048 {
00049 public:
00051 typedef NiftiImageIO Self;
00052 typedef ImageIOBase Superclass;
00053 typedef SmartPointer<Self> Pointer;
00054
00056 itkNewMacro(Self);
00057
00059 itkTypeMacro(NiftiImageIO, Superclass);
00060
00061
00062
00069 virtual bool CanReadFile(const char* FileNameToRead) ;
00070
00072 virtual void ReadImageInformation();
00073
00075 virtual void Read(void* buffer);
00076
00077
00078
00085 virtual bool CanWriteFile(const char * FileNameToWrite);
00086
00088 virtual void WriteImageInformation();
00089
00092 virtual void Write(const void* buffer);
00093
00094
00095 protected:
00096 NiftiImageIO();
00097 ~NiftiImageIO();
00098 void PrintSelf(std::ostream& os, Indent indent) const;
00099 private:
00100 void DefineHeaderObjectDataType();
00116 typedef enum {
00117 ITK_ANALYZE_ORIENTATION_RPI_TRANSVERSE=0,
00118 ITK_ANALYZE_ORIENTATION_RIP_CORONAL =1,
00119 ITK_ANALYZE_ORIENTATION_PIR_SAGITTAL =2,
00120 ITK_ANALYZE_ORIENTATION_RAI_TRANSVERSE_FLIPPED=3,
00121 ITK_ANALYZE_ORIENTATION_RSP_CORONAL_FLIPPED=4,
00122 ITK_ANALYZE_ORIENTATION_PIL_SAGITTAL_FLIPPED=5
00123 } ValidNiftiOrientationFlags;
00124 nifti_image * m_NiftiImage;
00125 double m_RescaleSlope;
00126 double m_RescaleIntercept;
00127
00128 NiftiImageIO(const Self&);
00129 void operator=(const Self&);
00130 };
00131 }
00132
00133 #endif // __itkNiftiImageIO_h