Main Page   Groups   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Concepts

itkSiemensVisionImageIO.h

Go to the documentation of this file.
00001 /*========================================================================= 00002 00003 Program: Insight Segmentation & Registration Toolkit 00004 Module: $RCSfile: itkSiemensVisionImageIO.h,v $ 00005 Language: C++ 00006 Date: $Date: 2003/09/10 14:29:36 $ 00007 Version: $Revision: 1.6 $ 00008 00009 Copyright (c) Insight Software Consortium. All rights reserved. 00010 See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details. 00011 00012 This software is distributed WITHOUT ANY WARRANTY; without even 00013 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 00014 PURPOSE. See the above copyright notices for more information. 00015 00016 =========================================================================*/ 00017 00031 #ifndef __itkSiemensVisionImageIO_h 00032 #define __itkSiemensVisionImageIO_h 00033 00034 #ifdef _MSC_VER 00035 #pragma warning ( disable : 4786 ) 00036 #endif 00037 00038 #include <fstream> 00039 #include "itkImageIOBase.h" 00040 #include "itkIPLCommonImageIO.h" 00041 #include "itkGEImageHeader.h" 00042 00043 namespace itk 00044 { 00049 class ITK_EXPORT SiemensVisionImageIO : public IPLCommonImageIO 00050 { 00051 public: 00053 typedef SiemensVisionImageIO Self; 00054 typedef IPLCommonImageIO Superclass; 00055 typedef SmartPointer<Self> Pointer; 00056 00058 itkNewMacro(Self); 00059 00061 itkTypeMacro(SiemensVisionImageIO, Superclass); 00062 00063 /*-------- This part of the interfaces deals with reading data. ----- */ 00064 00071 virtual bool CanReadFile(const char* FileNameToRead) ; 00072 00074 // Implemented in superclass 00075 // virtual void ReadImageInformation(); 00076 00078 // Implemented in superclass 00079 // virtual const std::type_info& GetPixelType() const; 00080 00082 // Implemented in superclass 00083 // virtual void Read(void* buffer); 00084 00088 // Implemented in superclass 00089 // virtual unsigned int GetComponentSize() const; 00090 00091 /*-------- This part of the interfaces deals with writing data. ----- */ 00092 00099 // Implemented in superclass 00100 // virtual bool CanWriteFile(const char * FileNameToWrite); 00101 00103 // Implemented in superclass 00104 // virtual void WriteImageInformation(); 00105 00108 // Implemented in superclass 00109 // virtual void Write(const void* buffer); 00110 protected: 00111 SiemensVisionImageIO(); 00112 ~SiemensVisionImageIO(); 00113 // Implemented in superclass 00114 // void PrintSelf(std::ostream& os, Indent indent) const; 00115 virtual struct GEImageHeader *ReadHeader(const char *FileNameToRead); 00116 private: 00117 typedef enum { 00118 HDR_STUDY_YEAR= 0, // Study date year, u_int 00119 HDR_STUDY_YEAR_LEN= 4, 00120 HDR_STUDY_MONTH= 4, // Study date month, u_int 00121 HDR_STUDY_MONTH_LEN= 4, 00122 HDR_STUDY_DAY= 8, // Study date day, u_int 00123 HDR_STUDY_DAY_LEN= 4, 00124 HDR_ACQ_YEAR= 12, // Acquisition date year, u_int 00125 HDR_ACQ_YEAR_LEN= 4, 00126 HDR_ACQ_MONTH= 16, // Acquisition date month, u_int 00127 HDR_ACQ_MONTH_LEN= 4, 00128 HDR_ACQ_DAY= 20, // Acquisition date day, u_int 00129 HDR_ACQ_DAY_LEN= 4, 00130 HDR_IMAGE_YEAR= 24, // Image date year, u_int 00131 HDR_IMAGE_YEAR_LEN= 4, 00132 HDR_IMAGE_MONTH= 28, // Image date month, u_int 00133 HDR_IMAGE_MONTH_LEN= 4, 00134 HDR_IMAGE_DAY= 32, // Image date day, u_int 00135 HDR_IMAGE_DAY_LEN= 4, 00136 HDR_STUDY_HOUR= 36, // Study time hour, u_int 00137 HDR_STUDY_HOUR_LEN= 4, 00138 HDR_STUDY_MIN= 40, // Study time minute, u_int 00139 HDR_STUDY_MIN_LEN= 4, 00140 HDR_STUDY_SEC= 44, // Study time second, u_int 00141 HDR_STUDY_SEC_LEN= 4, 00142 HDR_ACQ_HOUR= 52, // Acquisition time second, u_int 00143 HDR_ACQ_HOUR_LEN= 4, 00144 HDR_ACQ_MIN= 56, // Acquisition time second, u_int 00145 HDR_ACQ_MIN_LEN= 4, 00146 HDR_ACQ_SEC= 60, // Acquisition time second, u_int 00147 HDR_ACQ_SEC_LEN= 4, 00148 HDR_IMAGE_HOUR= 68, // Image Creation time second, u_int 00149 HDR_IMAGE_HOUR_LEN= 4, 00150 HDR_IMAGE_MIN= 72, // Image Creation time second, u_int 00151 HDR_IMAGE_MIN_LEN= 4, 00152 HDR_IMAGE_SEC= 76, // Image Creation time second, u_int 00153 HDR_IMAGE_SEC_LEN= 4, 00154 HDR_MANUFAC= 96, // Scanner Manufacturer, char 00155 HDR_MANUFAC_LEN= 7, 00156 HDR_INSTUTE_NAME= 105, // Institution Name, char 00157 HDR_INSTUTE_NAME_LEN= 25, 00158 HDR_ANNOTATION= 186, // Annotation, char 00159 HDR_ANNOTATION_LEN= 32, 00160 HDR_MODEL_NAME= 281, // Scanner Model Name, char 00161 HDR_MODEL_NAME_LEN= 12, 00162 HDR_LMOVE_YEAR= 412, // Date of Last Image Move - year, u_int 00163 HDR_LMOVE_YEAR_LEN= 4, 00164 HDR_LMOVE_MONTH= 416, // Date of Last Image Move - month, u_int 00165 HDR_LMOVE_MONTH_LEN= 4, 00166 HDR_LMOVE_DAY= 420, // Date of Last Image Move - day, u_int 00167 HDR_LMOVE_DAY_LEN= 4, 00168 HDR_LMOVE_HOUR= 424, // Date of Last Image Move - hour, u_int 00169 HDR_LMOVE_HOUR_LEN= 4, 00170 HDR_LMOVE_MIN= 428, // Date of Last Image Move - minute, u_int 00171 HDR_LMOVE_MIN_LEN= 4, 00172 HDR_LMOVE_SEC= 432, // Date of Last Image Move - second, u_int 00173 HDR_LMOVE_SEC_LEN= 4, 00174 HDR_PAT_NAME= 768, // Patient Name, char 00175 HDR_PAT_NAME_LEN= 25, 00176 HDR_PAT_ID= 795, // Patient ID Number, char 00177 HDR_PAT_ID_LEN= 12, 00178 HDR_DOB_YEAR= 808, // Date of Birth year, u_int 00179 HDR_DOB_YEAR_LEN= 4, 00180 HDR_DOB_MONTH= 812, // Date of Birth month, u_int 00181 HDR_DOB_MONTH_LEN= 4, 00182 HDR_DOB_DAY= 816, // Date of Birth day, u_int 00183 HDR_DOB_DAY_LEN= 4, 00184 HDR_PAT_AGE= 851, // Patient Age, char 00185 HDR_PAT_AGE_LEN= 3, 00186 HDR_AGE_UNIT= 854, // Patient Age Unit, char 00187 HDR_AGE_UNIT_LEN= 1, 00188 HDR_REG_YEAR= 1052, // Registration Date year, u_int 00189 HDR_REG_YEAR_LEN= 4, 00190 HDR_REG_MONTH= 1056, // Registration Date month, u_int 00191 HDR_REG_MONTH_LEN= 4, 00192 HDR_REG_DAY= 1060, // Registration Date day, u_int 00193 HDR_REG_DAY_LEN= 4, 00194 HDR_REG_HOUR= 1064, // Registration Time hour, u_int 00195 HDR_REG_HOUR_LEN= 4, 00196 HDR_REG_MIN= 1068, // Registration Time minute, u_int 00197 HDR_REG_MIN_LEN= 4, 00198 HDR_REG_SEC= 1072, // Registration Time second, u_int 00199 HDR_REG_SEC_LEN= 4, 00200 HDR_SLICE_THCK= 1544, // Slice thickness, double 00201 HDR_SLICE_THCK_LEN= 8, 00202 HDR_TR= 1560, // TR, double 00203 HDR_TR_LEN= 8, 00204 HDR_TE= 1568, // TE, double 00205 HDR_TE_LEN= 8, 00206 HDR_FREQ= 1592, // Center Frequency, double 00207 HDR_FREQ_LEN= 8, 00208 HDR_STATION= 1639, // Station Name, char 00209 HDR_STATION_LEN= 5, 00210 HDR_CAL_YEAR= 1712, // Calibration Date - year, u_int 00211 HDR_CAL_YEAR_LEN= 4, 00212 HDR_CAL_MONTH= 1716, // Calibration Date - month, u_int 00213 HDR_CAL_MONTH_LEN= 4, 00214 HDR_CAL_DAY= 1720, // Calibration Date - day, u_int 00215 HDR_CAL_DAY_LEN= 4, 00216 HDR_CAL_HOUR= 1724, // Calibration Time - hour, u_int 00217 HDR_CAL_HOUR_LEN= 4, 00218 HDR_CAL_MIN= 1728, // Calibration Time - minute, u_int 00219 HDR_CAL_MIN_LEN= 4, 00220 HDR_CAL_SEC= 1732, // Calibration Time - second, u_int 00221 HDR_CAL_SEC_LEN= 4, 00222 HDR_COIL= 1767, // Recieve Coil, char 00223 HDR_COIL_LEN= 16, 00224 HDR_IMAGE_NUC= 1828, // Imaged Nucleus, char 00225 HDR_IMAGE_NUC_LEN= 4, 00226 HDR_FLIP_ANGLE= 2112, // Flip Angle, double 00227 HDR_FLIP_ANGLE_LEN= 8, 00228 HDR_FIELD= 2560, // Field Strength, double 00229 HDR_FIELD_LEN= 8, 00230 HDR_DISPLAY_SIZE= 2864, // Displayed Matrix Size, u_int 00231 HDR_DISPLAY_SIZE_LEN= 4, 00232 HDR_SEQPROG_NAME= 2944, // Pulse Sequence Program Name, cha 00233 HDR_SEQPROG_NAME_LEN= 65, 00234 HDR_WKC_NAME= 3009, // Pulse Sequence Name, char 00235 HDR_WKC_NAME_LEN= 65, 00236 HDR_AUTHOR= 3074, // Pulse Sequence Author, char 00237 HDR_AUTHOR_LEN= 9, 00238 HDR_SEQUENCE_TYPE= 3083, // Pulse Sequence Type, char 00239 HDR_SEQUENCE_TYPE_LEN= 8, 00240 HDR_FOV_ROW= 3744, // Row FOV, double 00241 HDR_FOV_ROW_LEN= 8, 00242 HDR_FOV_COLUMN= 3752, // Column FOV, double 00243 HDR_FOV_COLUMN_LEN= 8, 00244 HDR_CENTER_X= 3768, // X Center Point, double 00245 HDR_CENTER_X_LEN= 8, 00246 HDR_CENTER_Y= 3776, // Y Center Point, double 00247 HDR_CENTER_Y_LEN= 8, 00248 HDR_CENTER_Z= 3784, // Z Center Point, double 00249 HDR_CENTER_Z_LEN= 8, 00250 HDR_NORMV_X= 3792, // Nornal Vector X, double 00251 HDR_NORMV_X_LEN= 8, 00252 HDR_NORMV_Y= 3800, // Nornal Vector Y, double 00253 HDR_NORMV_Y_LEN= 8, 00254 HDR_NORMV_Z= 3808, // Nornal Vector Z, double 00255 HDR_NORMV_Z_LEN= 8, 00256 HDR_DIST_ISO= 3816, // Distance from Isocenter, double 00257 HDR_DIST_ISO_LEN= 8, 00258 HDR_ROWV_X= 3832, // Row vector X, double 00259 HDR_ROWV_X_LEN= 8, 00260 HDR_ROWV_Y= 3840, // Row vector Y, double 00261 HDR_ROWV_Y_LEN= 8, 00262 HDR_ROWV_Z= 3848, // Row vector Z, double 00263 HDR_ROWV_Z_LEN= 8, 00264 HDR_COLMNV_X= 3856, // Column vector X, double 00265 HDR_COLMNV_X_LEN= 8, 00266 HDR_COLMNV_Y= 3864, // Column vector Y, double 00267 HDR_COLMNV_Y_LEN= 8, 00268 HDR_COLMNV_Z= 3872, // Column vector Z, double 00269 HDR_COLMNV_Z_LEN= 8, 00270 HDR_ORNT_SET1X= 3880, // Orientation Set 1 - X, char 00271 HDR_ORNT_SET1X_LEN= 3, 00272 HDR_ORNT_SET1Y= 3884, // Orientation Set 1 - Y, char 00273 HDR_ORNT_SET1Y_LEN= 3, 00274 HDR_ORNT_SET1Z= 3888, // Orientation Set 1 - Z, char 00275 HDR_ORNT_SET1Z_LEN= 3, 00276 HDR_ORNT_SET2X= 3892, // Orientation Set 2 - X, char 00277 HDR_ORNT_SET2X_LEN= 3, 00278 HDR_ORNT_SET2Y= 3896, // Orientation Set 2 - Y, char 00279 HDR_ORNT_SET2Y_LEN= 3, 00280 HDR_ORNT_SET2Z= 3900, // Orientation Set 2 - Z, char 00281 HDR_ORNT_SET2Z_LEN= 3, 00282 HDR_PROTOCOL_NAME= 2944, // Pulse Sequence Name, char 00283 HDR_PROTOCOL_NAME_LEN= 64, 00284 HDR_PIXELSIZE_ROW= 5000, // Row Pixel Size, double 00285 HDR_PIXELSIZE_ROW_LEN= 8, 00286 HDR_PIXELSIZE_CLMN= 5008, // Column Pixel Size, double 00287 HDR_PIXELSIZE_CLMN_LEN= 8, 00288 TEXT_PAT_ID= 5504, // Text Patient ID, char 00289 TEXT_PAT_ID_LEN= 12, 00290 TEXT_PAT_SEX= 5517, // Text Patient Sex, char 00291 TEXT_PAT_SEX_LEN= 1, 00292 TEXT_PAT_AGE= 5518, // Text Patient Age, char 00293 TEXT_PAT_AGE_LEN= 3, 00294 TEXT_AGE_UNIT= 5521, // Text Patient Age Unit (Y=year), char 00295 TEXT_AGE_UNIT_LEN= 1, 00296 TEXT_PAT_POS= 5529, // Text Patient Postion, char 00297 TEXT_PAT_POS_LEN= 7, 00298 TEXT_IMG_FLAG= 5541, // Text Image Flag (IMAGE=image), char 00299 TEXT_IMG_FLAG_LEN= 5, 00300 TEXT_IMG_NUMBER= 5546, // Text Image Number, char 00301 TEXT_IMG_NUMBER_LEN= 4, 00302 TEXT_IMG_DAY= 5559, // Text Date - Day, char 00303 TEXT_IMG_DAY_LEN= 2, 00304 TEXT_IMG_MONTH= 5562, // Text Date - Month, char 00305 TEXT_IMG_MONTH_LEN= 3, 00306 TEXT_IMG_YEAR= 5566, // Text Date - Year, char 00307 TEXT_IMG_YEAR_LEN= 4, 00308 TEXT_IMG_HOUR= 5571, // Text Time - hour, char 00309 TEXT_IMG_HOUR_LEN= 2, 00310 TEXT_IMG_MIN= 5574, // Text Time - minute, char 00311 TEXT_IMG_MIN_LEN= 2, 00312 TEXT_ACQ_FLAG= 5577, // Text Acq. Time Flag (TA=time of acq), char 00313 TEXT_ACQ_FLAG_LEN= 2, 00314 TEXT_ACQ_MIN= 5583, // Text Acq Time - minute, char 00315 TEXT_ACQ_MIN_LEN= 2, 00316 TEXT_ACQ_SEC= 5586, // Text Acq Time - second, char 00317 TEXT_ACQ_SEC_LEN= 2, 00318 TEXT_ANNOTATION= 5601, // Text Annotation, char 00319 TEXT_ANNOTATION_LEN= 32, 00320 TEXT_ORGANIZATION= 5655, // Text Organization, char 00321 TEXT_ORGANIZATION_LEN= 25, 00322 TEXT_STATION= 5682, // Text Station Name, char 00323 TEXT_STATION_LEN= 5, 00324 TEXT_ACQ_MTRX_PHASE= 5695, // Acq. Matrix Phase Axis, char 00325 TEXT_ACQ_MTRX_PHASE_LEN= 3, 00326 TEXT_ACQ_PHASE_DIR= 5698, // Acq. phase direction (h=hor, v=vert), char 00327 TEXT_ACQ_PHASE_DIR_LEN= 1, 00328 TEXT_ACQ_MTRX_FREQ= 5700, // Acq. matrix Freq Axis, char 00329 TEXT_ACQ_MTRX_FREQ_LEN= 3, 00330 TEXT_ACQ_MTRX_FREQO= 5703, // Acq freq (o=o " "=blank), char 00331 TEXT_ACQ_MTRX_FREQO_LEN= 1, 00332 TEXT_ACQ_MTRX_FREQS= 5704, // Acq freq (s=s " "=blank), char 00333 TEXT_ACQ_MTRX_FREQS_LEN= 1, 00334 TEXT_SEQUENCE= 5706, // Sequence Type, char 00335 TEXT_SEQUENCE_LEN= 8, 00336 TEXT_FLIP_ANGLE= 5714, // Flip Angle, char 00337 TEXT_FLIP_ANGLE_LEN= 3, 00338 TEXT_SCAN_FLAG= 5718, // Scan flag ("SCAN"), char */ 00339 TEXT_SCAN_FLAG_LEN= 4, 00340 TEXT_SCANA_NUM= 5723, // Scan Number A, char 00341 TEXT_SCANA_NUM_LEN= 3, 00342 TEXT_SCANB_NUM= 5726, // Scan Number B, char 00343 TEXT_SCANB_NUM_LEN= 3, 00344 TEXT_TR_FLAG= 5730, // TR flag ("TR"), char 00345 TEXT_TR_FLAG_LEN= 2, 00346 TEXT_TR= 5734, // TR, char 00347 TEXT_TR_LEN= 7, 00348 TEXT_TE_FLAG= 5742, // TE flag ("TE"), char 00349 TEXT_TE_FLAG_LEN= 2, 00350 TEXT_TE= 5746, // TE, char 00351 TEXT_TE_LEN= 5, 00352 TEXT_ECHO_NUM= 5752, // Echo number, char 00353 TEXT_ECHO_NUM_LEN= 1, 00354 TEXT_THCK_FLAG= 5790, // SLice thickness flag ("SL"), char 00355 TEXT_THCK_FLAG_LEN= 2, 00356 TEXT_SLICE_THCK= 5794, // Slice thickness 00357 TEXT_SLICE_THCK_LEN= 7, 00358 TEXT_POS_FLAG= 5802, // Slice postion flag ("SP"), char 00359 TEXT_POS_FLAG_LEN= 2, 00360 TEXT_SLICE_POS= 5806, // Slice postion, char 00361 TEXT_SLICE_POS_LEN= 7, 00362 TEXT_ANGLE_FLAG1= 5814, // Angle flag 1 ("Sag","Cor",or,"Tra"), char 00363 TEXT_ANGLE_FLAG1_LEN= 3, 00364 TEXT_ANGLE_FLAG2= 5817, // Angle flag 2 ("<", or ">"), char 00365 TEXT_ANGLE_FLAG2_LEN= 1, 00366 TEXT_ANGLE_FLAG3= 5818, // Angle flag 3 ("Sag","Cor",or,"Tra"), char 00367 TEXT_ANGLE_FLAG3_LEN= 3, 00368 TEXT_ANGLE= 5821, // Angle, char 00369 TEXT_ANGLE_LEN= 4, 00370 TEXT_FOV_FLAG= 5838, // FOV flag ("FOV"), char 00371 TEXT_FOV_FLAG_LEN= 3, 00372 TEXT_FOVH= 5842, // Horizontal FOV, char 00373 TEXT_FOVH_LEN= 3, 00374 TEXT_FOVV= 5846, // Vertical FOV, char 00375 TEXT_FOVV_LEN= 3, 00376 TEXT_TABLEPOS_FLAG= 5874, // Table Postion flag ("TP"), char 00377 TEXT_TABLEPOS_FLAG_LEN= 2, 00378 TEXT_TABLE_POS= 5878, // Table postion 00379 TEXT_TABLE_POS_LEN= 7, 00380 TEXT_STUDY_FLAG= 5938, // Study flag ("STUDY"), char 00381 TEXT_STUDY_FLAG_LEN= 5, 00382 TEXT_STUDY_NUM= 5943, // Study number, char 00383 TEXT_STUDY_NUM_LEN= 2, 00384 TEXT_DOB_DAY= 5956, // Date of Birth - day, char 00385 TEXT_DOB_DAY_LEN= 2, 00386 TEXT_DOB_MONTH= 5959, // Date of Birth - month, char 00387 TEXT_DOB_MONTH_LEN= 3, 00388 TEXT_DOB_YEAR= 5963, // Date of Birth - year, char 00389 TEXT_DOB_YEAR_LEN= 4, 00390 TEXT_STUDY_FLAG2= 5992, // Study flag 2 ("STU"), char 00391 TEXT_STUDY_FLAG2_LEN= 3, 00392 TEXT_IMAGE_FLAG2= 5996, // Image flag 2 ("IMA"), char 00393 TEXT_IMAGE_FLAG2_LEN= 3, 00394 TEXT_STUDY_NUM2= 5999, // Study number 2, char 00395 TEXT_STUDY_NUM2_LEN= 2, 00396 TEXT_IMAGE_NUM2= 6002, // Image number 2, char 00397 TEXT_IMAGE_NUM2_LEN= 2, 00398 TEXT_IMAGE_NUM3= 6013, // Image number 3, char 00399 TEXT_IMAGE_NUM3_LEN= 5, 00400 TEXT_MODEL_NAME= 6031, // Model Name, char 00401 TEXT_MODEL_NAME_LEN= 15, 00402 TEXT_PAT_NAME= 6058, // Patient Name, char 00403 TEXT_PAT_NAME_LEN= 25, 00404 TEXT_START_HOUR= 6085, // Scan start time - hour, char 00405 TEXT_START_HOUR_LEN= 2, 00406 TEXT_START_MIN= 6088, // Scan start time - minute, char 00407 TEXT_START_MIN_LEN= 2, 00408 TEXT_START_SEC= 6091, // Scan start time - second, char 00409 TEXT_START_SEC_LEN= 2, 00410 HDR_TOTAL_LENGTH= 6144, // Total length of Siemens Header 00411 } SiemensVisionHeaderInfo ; 00412 SiemensVisionImageIO(const Self&); //purposely not implemented 00413 void operator=(const Self&); //purposely not implemented 00414 }; 00415 00416 } // end namespace itk 00417 00418 #endif // __itkSiemensVisionImageIO_h

Generated at Sat Mar 31 02:29:13 2007 for ITK by doxygen 1.3.8 written by Dimitri van Heesch, © 1997-2000