forked from Kitware/VTK
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathvtkDICOMImageReader.h
228 lines (187 loc) · 6.26 KB
/
vtkDICOMImageReader.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
/*=========================================================================
Program: Visualization Toolkit
Module: vtkDICOMImageReader.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
// .NAME vtkDICOMImageReader - Reads some DICOM images
// .SECTION Description
// DICOM (stands for Digital Imaging in COmmunications and Medicine)
// is a medical image file format widely used to exchange data, provided
// by various modalities.
// .SECTION Warnings
// This reader might eventually handle ACR-NEMA file (predecessor of the DICOM
// format for medical images).
// This reader does not handle encapsulated format, only plain raw file are
// handled. This reader also does not handle multi-frames DICOM datasets.
// .SECTION Warnings
// Internally DICOMParser assumes the x,y pixel spacing is stored in 0028,0030 and
// that z spacing is stored in Slice Thickness (correct only when slice were acquired
// contiguous): 0018,0050. Which means this is only valid for some rare
// MR Image Storage
//
// .SECTION See Also
// vtkBMPReader vtkPNMReader vtkTIFFReader
#ifndef __vtkDICOMImageReader_h
#define __vtkDICOMImageReader_h
#include "vtkImageReader2.h"
//BTX
class vtkDICOMImageReaderVector;
class DICOMParser;
class DICOMAppHelper;
//ETX
class VTK_IO_EXPORT vtkDICOMImageReader : public vtkImageReader2
{
public:
// Description:
// Static method for construction.
static vtkDICOMImageReader *New();
vtkTypeMacro(vtkDICOMImageReader,vtkImageReader2);
// Description:
// Prints the ivars.
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Set the filename for the file to read. If this method is used,
// the reader will only read a single file.
void SetFileName(const char* fn)
{
if (this->DirectoryName)
{
delete [] this->DirectoryName;
}
if (this->FileName)
{
delete [] this->FileName;
}
this->DirectoryName = NULL;
this->FileName = NULL;
this->vtkImageReader2::SetFileName(fn);
}
// Description:
// Set the directory name for the reader to look in for DICOM
// files. If this method is used, the reader will try to find
// all the DICOM files in a directory. It will select the subset
// corresponding to the first series UID it stumbles across and
// it will try to build an ordered volume from them based on
// the slice number. The volume building will be upgraded to
// something more sophisticated in the future.
void SetDirectoryName(const char* dn);
// Description:
// Returns the directory name.
vtkGetStringMacro(DirectoryName);
// Description:
// Returns the pixel spacing (in X, Y, Z).
// Note: if there is only one slice, the Z spacing is set to the slice
// thickness. If there is more than one slice, it is set to the distance
// between the first two slices.
double* GetPixelSpacing();
// Description:
// Returns the image width.
int GetWidth();
// Description:
// Returns the image height.
int GetHeight();
// Description:
// Get the (DICOM) x,y,z coordinates of the first pixel in the
// image (upper left hand corner) of the last image processed by the
// DICOMParser
float* GetImagePositionPatient();
// Description:
// Get the (DICOM) directions cosines. It consist of the components
// of the first two vectors. The third vector needs to be computed
// to form an orthonormal basis.
float* GetImageOrientationPatient();
// Description:
// Get the number of bits allocated for each pixel in the file.
int GetBitsAllocated();
// Description:
// Get the pixel representation of the last image processed by the
// DICOMParser. A zero is a unsigned quantity. A one indicates a
// signed quantity
int GetPixelRepresentation();
// Description:
// Get the number of components of the image data for the last
// image processed.
int GetNumberOfComponents();
// Description:
// Get the transfer syntax UID for the last image processed.
const char* GetTransferSyntaxUID();
// Description:
// Get the rescale slope for the pixel data.
float GetRescaleSlope();
// Description:
// Get the rescale offset for the pixel data.
float GetRescaleOffset();
// Description:
// Get the patient name for the last image processed.
const char* GetPatientName();
// Description:
// Get the study uid for the last image processed.
const char* GetStudyUID();
// Description:
// Get the Study ID for the last image processed.
const char* GetStudyID();
// Description:
// Get the gantry angle for the last image processed.
float GetGantryAngle();
//
// Can I read the file?
//
virtual int CanReadFile(const char* fname);
//
// What file extensions are supported?
//
virtual const char* GetFileExtensions()
{
return ".dcm";
}
// Description:
// Return a descriptive name for the file format that might be useful in a GUI.
virtual const char* GetDescriptiveName()
{
return "DICOM";
}
protected:
//
// Setup the volume size
//
void SetupOutputInformation(int num_slices);
virtual void ExecuteInformation();
virtual void ExecuteData(vtkDataObject *out);
//
// Constructor
//
vtkDICOMImageReader();
//
// Destructor
//
virtual ~vtkDICOMImageReader();
//
// Instance of the parser used to parse the file.
//
DICOMParser* Parser;
//
// Instance of the callbacks that get the data from the file.
//
DICOMAppHelper* AppHelper;
//
// vtkDICOMImageReaderVector wants to be a PIMPL and it will be, but not quite yet.
//
vtkDICOMImageReaderVector* DICOMFileNames;
char* DirectoryName;
char* PatientName;
char* StudyUID;
char* StudyID;
char* TransferSyntaxUID;
// DICOMFileNames accessor methods for subclasses:
int GetNumberOfDICOMFileNames();
const char* GetDICOMFileName(int index);
private:
vtkDICOMImageReader(const vtkDICOMImageReader&); // Not implemented.
void operator=(const vtkDICOMImageReader&); // Not implemented.
};
#endif