00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
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 {
00052 class ITK_EXPORT SiemensVisionImageIO : public IPLCommonImageIO
00053 {
00054 public:
00056 typedef SiemensVisionImageIO Self;
00057 typedef IPLCommonImageIO Superclass;
00058 typedef SmartPointer<Self> Pointer;
00059
00061 itkNewMacro(Self);
00062
00064 itkTypeMacro(SiemensVisionImageIO, Superclass);
00065
00066
00067
00074 virtual bool CanReadFile(const char* FileNameToRead) ;
00075
00077
00078
00079
00081
00082
00083
00085
00086
00087
00091
00092
00093
00094
00095
00102
00103
00104
00106
00107
00108
00111
00112
00113 protected:
00114 SiemensVisionImageIO();
00115 ~SiemensVisionImageIO();
00116
00117
00118 virtual struct GEImageHeader *ReadHeader(const char *FileNameToRead);
00119 private:
00120 typedef enum {
00121 HDR_STUDY_YEAR= 0,
00122 HDR_STUDY_YEAR_LEN= 4,
00123 HDR_STUDY_MONTH= 4,
00124 HDR_STUDY_MONTH_LEN= 4,
00125 HDR_STUDY_DAY= 8,
00126 HDR_STUDY_DAY_LEN= 4,
00127 HDR_ACQ_YEAR= 12,
00128 HDR_ACQ_YEAR_LEN= 4,
00129 HDR_ACQ_MONTH= 16,
00130 HDR_ACQ_MONTH_LEN= 4,
00131 HDR_ACQ_DAY= 20,
00132 HDR_ACQ_DAY_LEN= 4,
00133 HDR_IMAGE_YEAR= 24,
00134 HDR_IMAGE_YEAR_LEN= 4,
00135 HDR_IMAGE_MONTH= 28,
00136 HDR_IMAGE_MONTH_LEN= 4,
00137 HDR_IMAGE_DAY= 32,
00138 HDR_IMAGE_DAY_LEN= 4,
00139 HDR_STUDY_HOUR= 36,
00140 HDR_STUDY_HOUR_LEN= 4,
00141 HDR_STUDY_MIN= 40,
00142 HDR_STUDY_MIN_LEN= 4,
00143 HDR_STUDY_SEC= 44,
00144 HDR_STUDY_SEC_LEN= 4,
00145 HDR_ACQ_HOUR= 52,
00146 HDR_ACQ_HOUR_LEN= 4,
00147 HDR_ACQ_MIN= 56,
00148 HDR_ACQ_MIN_LEN= 4,
00149 HDR_ACQ_SEC= 60,
00150 HDR_ACQ_SEC_LEN= 4,
00151 HDR_IMAGE_HOUR= 68,
00152 HDR_IMAGE_HOUR_LEN= 4,
00153 HDR_IMAGE_MIN= 72,
00154 HDR_IMAGE_MIN_LEN= 4,
00155 HDR_IMAGE_SEC= 76,
00156 HDR_IMAGE_SEC_LEN= 4,
00157 HDR_MANUFAC= 96,
00158 HDR_MANUFAC_LEN= 7,
00159 HDR_INSTUTE_NAME= 105,
00160 HDR_INSTUTE_NAME_LEN= 25,
00161 HDR_ANNOTATION= 186,
00162 HDR_ANNOTATION_LEN= 32,
00163 HDR_MODEL_NAME= 281,
00164 HDR_MODEL_NAME_LEN= 12,
00165 HDR_LMOVE_YEAR= 412,
00166 HDR_LMOVE_YEAR_LEN= 4,
00167 HDR_LMOVE_MONTH= 416,
00168 HDR_LMOVE_MONTH_LEN= 4,
00169 HDR_LMOVE_DAY= 420,
00170 HDR_LMOVE_DAY_LEN= 4,
00171 HDR_LMOVE_HOUR= 424,
00172 HDR_LMOVE_HOUR_LEN= 4,
00173 HDR_LMOVE_MIN= 428,
00174 HDR_LMOVE_MIN_LEN= 4,
00175 HDR_LMOVE_SEC= 432,
00176 HDR_LMOVE_SEC_LEN= 4,
00177 HDR_PAT_NAME= 768,
00178 HDR_PAT_NAME_LEN= 25,
00179 HDR_PAT_ID= 795,
00180 HDR_PAT_ID_LEN= 12,
00181 HDR_DOB_YEAR= 808,
00182 HDR_DOB_YEAR_LEN= 4,
00183 HDR_DOB_MONTH= 812,
00184 HDR_DOB_MONTH_LEN= 4,
00185 HDR_DOB_DAY= 816,
00186 HDR_DOB_DAY_LEN= 4,
00187 HDR_PAT_AGE= 851,
00188 HDR_PAT_AGE_LEN= 3,
00189 HDR_AGE_UNIT= 854,
00190 HDR_AGE_UNIT_LEN= 1,
00191 HDR_REG_YEAR= 1052,
00192 HDR_REG_YEAR_LEN= 4,
00193 HDR_REG_MONTH= 1056,
00194 HDR_REG_MONTH_LEN= 4,
00195 HDR_REG_DAY= 1060,
00196 HDR_REG_DAY_LEN= 4,
00197 HDR_REG_HOUR= 1064,
00198 HDR_REG_HOUR_LEN= 4,
00199 HDR_REG_MIN= 1068,
00200 HDR_REG_MIN_LEN= 4,
00201 HDR_REG_SEC= 1072,
00202 HDR_REG_SEC_LEN= 4,
00203 HDR_SLICE_THCK= 1544,
00204 HDR_SLICE_THCK_LEN= 8,
00205 HDR_TR= 1560,
00206 HDR_TR_LEN= 8,
00207 HDR_TE= 1568,
00208 HDR_TE_LEN= 8,
00209 HDR_FREQ= 1592,
00210 HDR_FREQ_LEN= 8,
00211 HDR_STATION= 1639,
00212 HDR_STATION_LEN= 5,
00213 HDR_CAL_YEAR= 1712,
00214 HDR_CAL_YEAR_LEN= 4,
00215 HDR_CAL_MONTH= 1716,
00216 HDR_CAL_MONTH_LEN= 4,
00217 HDR_CAL_DAY= 1720,
00218 HDR_CAL_DAY_LEN= 4,
00219 HDR_CAL_HOUR= 1724,
00220 HDR_CAL_HOUR_LEN= 4,
00221 HDR_CAL_MIN= 1728,
00222 HDR_CAL_MIN_LEN= 4,
00223 HDR_CAL_SEC= 1732,
00224 HDR_CAL_SEC_LEN= 4,
00225 HDR_COIL= 1767,
00226 HDR_COIL_LEN= 16,
00227 HDR_IMAGE_NUC= 1828,
00228 HDR_IMAGE_NUC_LEN= 4,
00229 HDR_FLIP_ANGLE= 2112,
00230 HDR_FLIP_ANGLE_LEN= 8,
00231 HDR_FIELD= 2560,
00232 HDR_FIELD_LEN= 8,
00233 HDR_DISPLAY_SIZE= 2864,
00234 HDR_DISPLAY_SIZE_LEN= 4,
00235 HDR_SEQPROG_NAME= 2944,
00236 HDR_SEQPROG_NAME_LEN= 65,
00237 HDR_WKC_NAME= 3009,
00238 HDR_WKC_NAME_LEN= 65,
00239 HDR_AUTHOR= 3074,
00240 HDR_AUTHOR_LEN= 9,
00241 HDR_SEQUENCE_TYPE= 3083,
00242 HDR_SEQUENCE_TYPE_LEN= 8,
00243 HDR_FOV_ROW= 3744,
00244 HDR_FOV_ROW_LEN= 8,
00245 HDR_FOV_COLUMN= 3752,
00246 HDR_FOV_COLUMN_LEN= 8,
00247 HDR_CENTER_X= 3768,
00248 HDR_CENTER_X_LEN= 8,
00249 HDR_CENTER_Y= 3776,
00250 HDR_CENTER_Y_LEN= 8,
00251 HDR_CENTER_Z= 3784,
00252 HDR_CENTER_Z_LEN= 8,
00253 HDR_NORMV_X= 3792,
00254 HDR_NORMV_X_LEN= 8,
00255 HDR_NORMV_Y= 3800,
00256 HDR_NORMV_Y_LEN= 8,
00257 HDR_NORMV_Z= 3808,
00258 HDR_NORMV_Z_LEN= 8,
00259 HDR_DIST_ISO= 3816,
00260 HDR_DIST_ISO_LEN= 8,
00261 HDR_ROWV_X= 3832,
00262 HDR_ROWV_X_LEN= 8,
00263 HDR_ROWV_Y= 3840,
00264 HDR_ROWV_Y_LEN= 8,
00265 HDR_ROWV_Z= 3848,
00266 HDR_ROWV_Z_LEN= 8,
00267 HDR_COLMNV_X= 3856,
00268 HDR_COLMNV_X_LEN= 8,
00269 HDR_COLMNV_Y= 3864,
00270 HDR_COLMNV_Y_LEN= 8,
00271 HDR_COLMNV_Z= 3872,
00272 HDR_COLMNV_Z_LEN= 8,
00273 HDR_ORNT_SET1X= 3880,
00274 HDR_ORNT_SET1X_LEN= 3,
00275 HDR_ORNT_SET1Y= 3884,
00276 HDR_ORNT_SET1Y_LEN= 3,
00277 HDR_ORNT_SET1Z= 3888,
00278 HDR_ORNT_SET1Z_LEN= 3,
00279 HDR_ORNT_SET2X= 3892,
00280 HDR_ORNT_SET2X_LEN= 3,
00281 HDR_ORNT_SET2Y= 3896,
00282 HDR_ORNT_SET2Y_LEN= 3,
00283 HDR_ORNT_SET2Z= 3900,
00284 HDR_ORNT_SET2Z_LEN= 3,
00285 HDR_PROTOCOL_NAME= 2944,
00286 HDR_PROTOCOL_NAME_LEN= 64,
00287 HDR_PIXELSIZE_ROW= 5000,
00288 HDR_PIXELSIZE_ROW_LEN= 8,
00289 HDR_PIXELSIZE_CLMN= 5008,
00290 HDR_PIXELSIZE_CLMN_LEN= 8,
00291 TEXT_PAT_ID= 5504,
00292 TEXT_PAT_ID_LEN= 12,
00293 TEXT_PAT_SEX= 5517,
00294 TEXT_PAT_SEX_LEN= 1,
00295 TEXT_PAT_AGE= 5518,
00296 TEXT_PAT_AGE_LEN= 3,
00297 TEXT_AGE_UNIT= 5521,
00298 TEXT_AGE_UNIT_LEN= 1,
00299 TEXT_PAT_POS= 5529,
00300 TEXT_PAT_POS_LEN= 7,
00301 TEXT_IMG_FLAG= 5541,
00302 TEXT_IMG_FLAG_LEN= 5,
00303 TEXT_IMG_NUMBER= 5546,
00304 TEXT_IMG_NUMBER_LEN= 4,
00305 TEXT_IMG_DAY= 5559,
00306 TEXT_IMG_DAY_LEN= 2,
00307 TEXT_IMG_MONTH= 5562,
00308 TEXT_IMG_MONTH_LEN= 3,
00309 TEXT_IMG_YEAR= 5566,
00310 TEXT_IMG_YEAR_LEN= 4,
00311 TEXT_IMG_HOUR= 5571,
00312 TEXT_IMG_HOUR_LEN= 2,
00313 TEXT_IMG_MIN= 5574,
00314 TEXT_IMG_MIN_LEN= 2,
00315 TEXT_ACQ_FLAG= 5577,
00316 TEXT_ACQ_FLAG_LEN= 2,
00317 TEXT_ACQ_MIN= 5583,
00318 TEXT_ACQ_MIN_LEN= 2,
00319 TEXT_ACQ_SEC= 5586,
00320 TEXT_ACQ_SEC_LEN= 2,
00321 TEXT_ANNOTATION= 5601,
00322 TEXT_ANNOTATION_LEN= 32,
00323 TEXT_ORGANIZATION= 5655,
00324 TEXT_ORGANIZATION_LEN= 25,
00325 TEXT_STATION= 5682,
00326 TEXT_STATION_LEN= 5,
00327 TEXT_ACQ_MTRX_PHASE= 5695,
00328 TEXT_ACQ_MTRX_PHASE_LEN= 3,
00329 TEXT_ACQ_PHASE_DIR= 5698,
00330 TEXT_ACQ_PHASE_DIR_LEN= 1,
00331 TEXT_ACQ_MTRX_FREQ= 5700,
00332 TEXT_ACQ_MTRX_FREQ_LEN= 3,
00333 TEXT_ACQ_MTRX_FREQO= 5703,
00334 TEXT_ACQ_MTRX_FREQO_LEN= 1,
00335 TEXT_ACQ_MTRX_FREQS= 5704,
00336 TEXT_ACQ_MTRX_FREQS_LEN= 1,
00337 TEXT_SEQUENCE= 5706,
00338 TEXT_SEQUENCE_LEN= 8,
00339 TEXT_FLIP_ANGLE= 5714,
00340 TEXT_FLIP_ANGLE_LEN= 3,
00341 TEXT_SCAN_FLAG= 5718,
00342 TEXT_SCAN_FLAG_LEN= 4,
00343 TEXT_SCANA_NUM= 5723,
00344 TEXT_SCANA_NUM_LEN= 3,
00345 TEXT_SCANB_NUM= 5726,
00346 TEXT_SCANB_NUM_LEN= 3,
00347 TEXT_TR_FLAG= 5730,
00348 TEXT_TR_FLAG_LEN= 2,
00349 TEXT_TR= 5734,
00350 TEXT_TR_LEN= 7,
00351 TEXT_TE_FLAG= 5742,
00352 TEXT_TE_FLAG_LEN= 2,
00353 TEXT_TE= 5746,
00354 TEXT_TE_LEN= 5,
00355 TEXT_ECHO_NUM= 5752,
00356 TEXT_ECHO_NUM_LEN= 1,
00357 TEXT_THCK_FLAG= 5790,
00358 TEXT_THCK_FLAG_LEN= 2,
00359 TEXT_SLICE_THCK= 5794,
00360 TEXT_SLICE_THCK_LEN= 7,
00361 TEXT_POS_FLAG= 5802,
00362 TEXT_POS_FLAG_LEN= 2,
00363 TEXT_SLICE_POS= 5806,
00364 TEXT_SLICE_POS_LEN= 7,
00365 TEXT_ANGLE_FLAG1= 5814,
00366 TEXT_ANGLE_FLAG1_LEN= 3,
00367 TEXT_ANGLE_FLAG2= 5817,
00368 TEXT_ANGLE_FLAG2_LEN= 1,
00369 TEXT_ANGLE_FLAG3= 5818,
00370 TEXT_ANGLE_FLAG3_LEN= 3,
00371 TEXT_ANGLE= 5821,
00372 TEXT_ANGLE_LEN= 4,
00373 TEXT_FOV_FLAG= 5838,
00374 TEXT_FOV_FLAG_LEN= 3,
00375 TEXT_FOVH= 5842,
00376 TEXT_FOVH_LEN= 3,
00377 TEXT_FOVV= 5846,
00378 TEXT_FOVV_LEN= 3,
00379 TEXT_TABLEPOS_FLAG= 5874,
00380 TEXT_TABLEPOS_FLAG_LEN= 2,
00381 TEXT_TABLE_POS= 5878,
00382 TEXT_TABLE_POS_LEN= 7,
00383 TEXT_STUDY_FLAG= 5938,
00384 TEXT_STUDY_FLAG_LEN= 5,
00385 TEXT_STUDY_NUM= 5943,
00386 TEXT_STUDY_NUM_LEN= 2,
00387 TEXT_DOB_DAY= 5956,
00388 TEXT_DOB_DAY_LEN= 2,
00389 TEXT_DOB_MONTH= 5959,
00390 TEXT_DOB_MONTH_LEN= 3,
00391 TEXT_DOB_YEAR= 5963,
00392 TEXT_DOB_YEAR_LEN= 4,
00393 TEXT_STUDY_FLAG2= 5992,
00394 TEXT_STUDY_FLAG2_LEN= 3,
00395 TEXT_IMAGE_FLAG2= 5996,
00396 TEXT_IMAGE_FLAG2_LEN= 3,
00397 TEXT_STUDY_NUM2= 5999,
00398 TEXT_STUDY_NUM2_LEN= 2,
00399 TEXT_IMAGE_NUM2= 6002,
00400 TEXT_IMAGE_NUM2_LEN= 2,
00401 TEXT_IMAGE_NUM3= 6013,
00402 TEXT_IMAGE_NUM3_LEN= 5,
00403 TEXT_MODEL_NAME= 6031,
00404 TEXT_MODEL_NAME_LEN= 15,
00405 TEXT_PAT_NAME= 6058,
00406 TEXT_PAT_NAME_LEN= 25,
00407 TEXT_START_HOUR= 6085,
00408 TEXT_START_HOUR_LEN= 2,
00409 TEXT_START_MIN= 6088,
00410 TEXT_START_MIN_LEN= 2,
00411 TEXT_START_SEC= 6091,
00412 TEXT_START_SEC_LEN= 2,
00413 HDR_TOTAL_LENGTH= 6144
00414 } SiemensVisionHeaderInfo;
00415 SiemensVisionImageIO(const Self&);
00416 void operator=(const Self&);
00417 };
00419
00420 }
00421
00422 #endif // __itkSiemensVisionImageIO_h
00423