forked from Kitware/VTK
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathvtkVolume16Reader.h
150 lines (125 loc) · 5.77 KB
/
vtkVolume16Reader.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
/*=========================================================================
Program: Visualization Toolkit
Module: vtkVolume16Reader.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 vtkVolume16Reader - read 16 bit image files
// .SECTION Description
// vtkVolume16Reader is a source object that reads 16 bit image files.
//
// Volume16Reader creates structured point datasets. The dimension of the
// dataset depends upon the number of files read. Reading a single file
// results in a 2D image, while reading more than one file results in a
// 3D volume.
//
// File names are created using FilePattern and FilePrefix as follows:
// sprintf (filename, FilePattern, FilePrefix, number);
// where number is in the range ImageRange[0] to ImageRange[1]. If
// ImageRange[1] <= ImageRange[0], then slice number ImageRange[0] is
// read. Thus to read an image set ImageRange[0] = ImageRange[1] = slice
// number. The default behavior is to read a single file (i.e., image slice 1).
//
// The DataMask instance variable is used to read data files with imbedded
// connectivity or segmentation information. For example, some data has
// the high order bit set to indicate connected surface. The DataMask allows
// you to select this data. Other important ivars include HeaderSize, which
// allows you to skip over initial info, and SwapBytes, which turns on/off
// byte swapping.
//
// The Transform instance variable specifies a permutation transformation
// to map slice space into world space. vtkImageReader has replaced the
// functionality of this class and should be used instead.
// .SECTION See Also
// vtkSliceCubes vtkMarchingCubes vtkImageReader
#ifndef __vtkVolume16Reader_h
#define __vtkVolume16Reader_h
#include "vtkVolumeReader.h"
class vtkTransform;
class vtkUnsignedCharArray;
class vtkUnsignedShortArray;
#define VTK_FILE_BYTE_ORDER_BIG_ENDIAN 0
#define VTK_FILE_BYTE_ORDER_LITTLE_ENDIAN 1
class VTK_IO_EXPORT vtkVolume16Reader : public vtkVolumeReader
{
public:
vtkTypeMacro(vtkVolume16Reader,vtkVolumeReader);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Construct object with NULL file prefix; file pattern "%s.%d"; image range
// set to (1,1); data origin (0,0,0); data spacing (1,1,1); no data mask;
// header size 0; and byte swapping turned off.
static vtkVolume16Reader *New();
// Description:
// Specify the dimensions for the data.
vtkSetVector2Macro(DataDimensions,int);
vtkGetVectorMacro(DataDimensions,int,2);
// Description:
// Specify a mask used to eliminate data in the data file (e.g.,
// connectivity bits).
vtkSetMacro(DataMask,unsigned short);
vtkGetMacro(DataMask,unsigned short);
// Description:
// Specify the number of bytes to seek over at start of image.
vtkSetMacro(HeaderSize,int);
vtkGetMacro(HeaderSize,int);
// Description:
// These methods should be used instead of the SwapBytes methods.
// They indicate the byte ordering of the file you are trying
// to read in. These methods will then either swap or not swap
// the bytes depending on the byte ordering of the machine it is
// being run on. For example, reading in a BigEndian file on a
// BigEndian machine will result in no swapping. Trying to read
// the same file on a LittleEndian machine will result in swapping.
// As a quick note most UNIX machines are BigEndian while PC's
// and VAX tend to be LittleEndian. So if the file you are reading
// in was generated on a VAX or PC, SetDataByteOrderToLittleEndian otherwise
// SetDataByteOrderToBigEndian.
void SetDataByteOrderToBigEndian();
void SetDataByteOrderToLittleEndian();
int GetDataByteOrder();
void SetDataByteOrder(int);
const char *GetDataByteOrderAsString();
// Description:
// Turn on/off byte swapping.
vtkSetMacro(SwapBytes,int);
vtkGetMacro(SwapBytes,int);
vtkBooleanMacro(SwapBytes,int);
// Description:
// Set/Get transformation matrix to transform the data from slice space
// into world space. This matrix must be a permutation matrix. To qualify,
// the sums of the rows must be + or - 1.
virtual void SetTransform(vtkTransform*);
vtkGetObjectMacro(Transform,vtkTransform);
// Description:
// Other objects make use of these methods
vtkImageData *GetImage(int ImageNumber);
protected:
vtkVolume16Reader();
~vtkVolume16Reader();
virtual int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
virtual int RequestInformation(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
int DataDimensions[2];
unsigned short DataMask;
int SwapBytes;
int HeaderSize;
vtkTransform *Transform;
void TransformSlice (unsigned short *slice, unsigned short *pixels, int k, int dimensions[3], int bounds[3]);
void ComputeTransformedDimensions(int dimensions[3]);
void ComputeTransformedBounds(int bounds[6]);
void ComputeTransformedSpacing(double Spacing[3]);
void ComputeTransformedOrigin(double origin[3]);
void AdjustSpacingAndOrigin(int dimensions[3], double Spacing[3], double origin[3]);
void ReadImage(int ImageNumber, vtkUnsignedShortArray *);
void ReadVolume(int FirstImage, int LastImage, vtkUnsignedShortArray *);
int Read16BitImage(FILE *fp, unsigned short *pixels, int xsize, int ysize,
int skip, int swapBytes);
private:
vtkVolume16Reader(const vtkVolume16Reader&); // Not implemented.
void operator=(const vtkVolume16Reader&); // Not implemented.
};
#endif