/usr/include/gdcm-2.4/gdcmImage.h is in libgdcm2-dev 2.4.4-3+deb8u1.
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 | /*=========================================================================
Program: GDCM (Grassroots DICOM). A DICOM library
Copyright (c) 2006-2011 Mathieu Malaterre
All rights reserved.
See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html 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.
=========================================================================*/
#ifndef GDCMIMAGE_H
#define GDCMIMAGE_H
#include "gdcmPixmap.h"
#include <vector>
namespace gdcm
{
/**
* \brief Image
* This is the container for an Image in the general sense.
* From this container you should be able to request information like:
* - Origin
* - Dimension
* - PixelFormat
* ...
* But also to retrieve the image as a raw buffer (char *)
* Since we have to deal with both RAW data and JPEG stream (which
* internally encode all the above information) this API might seems
* redundant. One way to solve that would be to subclass Image
* with JPEGImage which would from the stream extract the header info
* and fill it to please Image...well except origin for instance
*
* Basically you can see it as a storage for the Pixel Data element (7fe0,0010).
*
* \warning This class does some heuristics to guess the Spacing but is not
* compatible with DICOM CP-586. In case of doubt use PixmapReader instead
*
* \see ImageReader PixmapReader
*/
class GDCM_EXPORT Image : public Pixmap
{
public:
Image ():Spacing(),SC(),Intercept(0),Slope(1) {
//DirectionCosines.resize(6);
Origin.resize( 3 /*NumberOfDimensions*/ ); // fill with 0
DirectionCosines.resize( 6 ); // fill with 0
DirectionCosines[0] = 1;
DirectionCosines[4] = 1;
Spacing.resize( 3 /*NumberOfDimensions*/, 1 ); // fill with 1
}
~Image() {}
/// Return a 3-tuples specifying the spacing
/// NOTE: 3rd value can be an aribtrary 1 value when the spacing was not specified (ex. 2D image).
/// WARNING: when the spacing is not specifier, a default value of 1 will be returned
const double *GetSpacing() const;
double GetSpacing(unsigned int idx) const;
void SetSpacing(const double *spacing);
void SetSpacing(unsigned int idx, double spacing);
/// Return a 3-tuples specifying the origin
/// Will return (0,0,0) if the origin was not specified.
const double *GetOrigin() const;
double GetOrigin(unsigned int idx) const;
void SetOrigin(const float *ori);
void SetOrigin(const double *ori);
void SetOrigin(unsigned int idx, double ori);
/// Return a 6-tuples specifying the direction cosines
/// A default value of (1,0,0,0,1,0) will be return when the direction cosines was not specified.
const double *GetDirectionCosines() const;
double GetDirectionCosines(unsigned int idx) const;
void SetDirectionCosines(const float *dircos);
void SetDirectionCosines(const double *dircos);
void SetDirectionCosines(unsigned int idx, double dircos);
/// print
void Print(std::ostream &os) const;
/// intercept
void SetIntercept(double intercept) { Intercept = intercept; }
double GetIntercept() const { return Intercept; }
/// slope
void SetSlope(double slope) { Slope = slope; }
double GetSlope() const { return Slope; }
private:
std::vector<double> Spacing;
std::vector<double> Origin;
std::vector<double> DirectionCosines;
// I believe the following 3 ivars can be derived from TS ...
SwapCode SC;
double Intercept;
double Slope;
};
/**
* \example DecompressImage.cs
* This is a C# example on how to use Image
*/
} // end namespace gdcm
#endif //GDCMIMAGE_H
|