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
00096 virtual ImageIORegion
00097 GenerateStreamableReadRegionFromRequestedRegion( const ImageIORegion & requestedRegion ) const;
00098
00099 protected:
00100 NiftiImageIO();
00101 ~NiftiImageIO();
00102 void PrintSelf(std::ostream& os, Indent indent) const;
00103 private:
00104 bool MustRescale();
00105 void DefineHeaderObjectDataType();
00106 void SetNIfTIOrientationFromImageIO(int origdims, int dims);
00107 void SetImageIOOrientationFromNIfTI(int dims);
00123 typedef enum {
00124
00136 } ValidNiftiOrientationFlags;
00137
00138 nifti_image * m_NiftiImage;
00139 double m_RescaleSlope;
00140 double m_RescaleIntercept;
00141 IOComponentType m_OnDiskComponentType;
00142
00143 NiftiImageIO(const Self&);
00144 void operator=(const Self&);
00145 };
00146
00147 }
00148
00149 #endif // __itkNiftiImageIO_h
00150