/usr/include/vtk-7.1/vtkDICOMImageReader.h is in libvtk7-dev 7.1.1+dfsg1-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 | /*=========================================================================
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.
=========================================================================*/
/**
* @class vtkDICOMImageReader
* @brief Reads some DICOM images
*
* DICOM (stands for Digital Imaging in COmmunications and Medicine)
* is a medical image file format widely used to exchange data, provided
* by various modalities.
* @warning
* 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.
* @warning
* 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
*
* @sa
* vtkBMPReader vtkPNMReader vtkTIFFReader
*/
#ifndef vtkDICOMImageReader_h
#define vtkDICOMImageReader_h
#include "vtkIOImageModule.h" // For export macro
#include "vtkImageReader2.h"
class vtkDICOMImageReaderVector;
class DICOMParser;
class DICOMAppHelper;
class VTKIOIMAGE_EXPORT vtkDICOMImageReader : public vtkImageReader2
{
public:
//@{
/**
* Static method for construction.
*/
static vtkDICOMImageReader *New();
vtkTypeMacro(vtkDICOMImageReader,vtkImageReader2);
//@}
/**
* Prints the ivars.
*/
void PrintSelf(ostream& os, vtkIndent indent);
//@{
/**
* 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)
{
delete [] this->DirectoryName;
delete [] this->FileName;
this->DirectoryName = NULL;
this->FileName = NULL;
this->vtkImageReader2::SetFileName(fn);
}
//@}
/**
* 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);
//@{
/**
* Returns the directory name.
*/
vtkGetStringMacro(DirectoryName);
//@}
/**
* 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();
/**
* Returns the image width.
*/
int GetWidth();
/**
* Returns the image height.
*/
int GetHeight();
/**
* 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();
/**
* 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();
/**
* Get the number of bits allocated for each pixel in the file.
*/
int GetBitsAllocated();
/**
* 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();
/**
* Get the number of components of the image data for the last
* image processed.
*/
int GetNumberOfComponents();
/**
* Get the transfer syntax UID for the last image processed.
*/
const char* GetTransferSyntaxUID();
/**
* Get the rescale slope for the pixel data.
*/
float GetRescaleSlope();
/**
* Get the rescale offset for the pixel data.
*/
float GetRescaleOffset();
/**
* Get the patient name for the last image processed.
*/
const char* GetPatientName();
/**
* Get the study uid for the last image processed.
*/
const char* GetStudyUID();
/**
* Get the Study ID for the last image processed.
*/
const char* GetStudyID();
/**
* 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";
}
/**
* 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 ExecuteDataWithInformation(vtkDataObject *out, vtkInformation *outInfo);
//
// 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&) VTK_DELETE_FUNCTION;
void operator=(const vtkDICOMImageReader&) VTK_DELETE_FUNCTION;
};
#endif
|