vtkGDCMThreadedImageReader2.h
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044 #ifndef __vtkGDCMThreadedImageReader2_h
00045 #define __vtkGDCMThreadedImageReader2_h
00046
00047 #include "vtkThreadedImageAlgorithm.h"
00048 #include "gdcmTypes.h"
00049
00050 class vtkStringArray;
00051 class GDCM_EXPORT vtkGDCMThreadedImageReader2 : public vtkThreadedImageAlgorithm
00052 {
00053 public:
00054 static vtkGDCMThreadedImageReader2 *New();
00055 vtkTypeRevisionMacro(vtkGDCMThreadedImageReader2,vtkThreadedImageAlgorithm);
00056 virtual void PrintSelf(ostream& os, vtkIndent indent);
00057
00058 vtkGetMacro(FileLowerLeft,int);
00059 vtkSetMacro(FileLowerLeft,int);
00060 vtkBooleanMacro(FileLowerLeft,int);
00061
00062 vtkGetMacro(NumberOfOverlays,int);
00063
00064 vtkSetMacro(DataScalarType,int);
00065 vtkGetMacro(DataScalarType,int);
00066
00067 vtkSetMacro(NumberOfScalarComponents,int);
00068 vtkGetMacro(NumberOfScalarComponents,int);
00069
00070 vtkGetMacro(LoadOverlays,int);
00071 vtkSetMacro(LoadOverlays,int);
00072 vtkBooleanMacro(LoadOverlays,int);
00073
00074 vtkSetVector6Macro(DataExtent,int);
00075 vtkGetVector6Macro(DataExtent,int);
00076
00077 vtkSetVector3Macro(DataOrigin,double);
00078 vtkGetVector3Macro(DataOrigin,double);
00079
00080 vtkSetVector3Macro(DataSpacing,double);
00081 vtkGetVector3Macro(DataSpacing,double);
00082
00083
00084
00085 virtual const char *GetFileName(int i = 0);
00086 virtual void SetFileName(const char *filename);
00087
00088 virtual void SetFileNames(vtkStringArray*);
00089 vtkGetObjectMacro(FileNames, vtkStringArray);
00090
00091 int SplitExtent(int splitExt[6], int startExt[6],
00092 int num, int total);
00093
00094
00095
00096 vtkSetMacro(Shift,double);
00097 vtkGetMacro(Shift,double);
00098
00099
00100
00101 vtkSetMacro(Scale,double);
00102 vtkGetMacro(Scale,double);
00103
00104
00105
00106
00107 vtkSetMacro(UseShiftScale,int);
00108 vtkGetMacro(UseShiftScale,int);
00109 vtkBooleanMacro(UseShiftScale,int);
00110
00111 protected:
00112 vtkGDCMThreadedImageReader2();
00113 ~vtkGDCMThreadedImageReader2();
00114
00115 int RequestInformation(vtkInformation *request,
00116 vtkInformationVector **inputVector,
00117 vtkInformationVector *outputVector);
00118
00119 protected:
00120 void ThreadedRequestData (
00121 vtkInformation * request,
00122 vtkInformationVector** inputVector,
00123 vtkInformationVector * outputVector,
00124 vtkImageData ***inData,
00125 vtkImageData **outData,
00126 int outExt[6], int id);
00127
00128 private:
00129 int FileLowerLeft;
00130 char *FileName;
00131 vtkStringArray *FileNames;
00132 int LoadIconImage;
00133 int DataExtent[6];
00134 int LoadOverlays;
00135 int NumberOfOverlays;
00136 int DataScalarType;
00137
00138 int NumberOfScalarComponents;
00139 double DataSpacing[3];
00140 double DataOrigin[3];
00141 int IconImageDataExtent[6];
00142
00143 double Shift;
00144 double Scale;
00145 int UseShiftScale;
00146
00147 private:
00148 vtkGDCMThreadedImageReader2(const vtkGDCMThreadedImageReader2&);
00149 void operator=(const vtkGDCMThreadedImageReader2&);
00150 };
00151
00152 #endif