X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmFile.h;h=8e6e51adab74897ae5a5e5839f0ab235e80cc5a5;hb=697cf89322733e2a7bb52244b1b6b9b896969f0f;hp=106ce066fc70a07788efb35a8cd29d44facb4123;hpb=0591e5cbe0d6136167a7ff5f2086d893f2111d58;p=gdcm.git diff --git a/src/gdcmFile.h b/src/gdcmFile.h index 106ce066..8e6e51ad 100644 --- a/src/gdcmFile.h +++ b/src/gdcmFile.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmFile.h,v $ Language: C++ - Date: $Date: 2005/01/21 12:37:15 $ - Version: $Revision: 1.98 $ + Date: $Date: 2005/10/06 18:54:50 $ + Version: $Revision: 1.117 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -19,11 +19,17 @@ #ifndef GDCMFILE_H #define GDCMFILE_H +#include "gdcmDebug.h" #include "gdcmDocument.h" + + namespace gdcm { +class RLEFramesInfo; +class JPEGFragmentsInfo; + //----------------------------------------------------------------------------- // Dicom Part 3.3 Compliant enum ModalityType { @@ -72,6 +78,7 @@ enum ModalityType { }; //----------------------------------------------------------------------------- + /** * \brief DICOM elements and their corresponding values (and * additionaly the corresponding DICOM dictionary entry) of the header @@ -81,7 +88,7 @@ enum ModalityType { * dicom files according to header information e.g. to create a file hierarchy * reflecting the Patient/Study/Serie informations, or extracting a given * SerieId. Accessing the content (image[s] or volume[s]) is beyond the - * functionality of this class and belongs to gdmcFile. + * functionality of this class and belongs to gdcm::FileHelper. * \note The various entries of the explicit value representation (VR) shall * be managed within a dictionary which is shared by all File * instances. @@ -89,95 +96,111 @@ enum ModalityType { * protected due to Swig limitations for as Has_a dependency between * File and FileHelper. */ - -//----------------------------------------------------------------------------- - class GDCM_EXPORT File : public Document { -protected: - /// \brief In some cases (e.g. for some ACR-NEMA images) the Entry Element - /// Number of the 'Pixel Element' is *not* found at 0x0010. In order to - /// make things easier the parser shall store the proper value in - /// NumPixel to provide a unique access facility. - uint16_t NumPixel; - /// \brief In some cases (e.g. for some ACR-NEMA images) the header entry for - /// the group of pixels is *not* found at 0x7fe0. In order to - /// make things easier the parser shall store the proper value in - /// GrPixel to provide a unique access facility. - uint16_t GrPixel; - public: File(); - File( std::string const &filename ); - + GDCM_LEGACY(File( std::string const &filename )); ~File(); + // Loading + GDCM_LEGACY(bool Load( std::string const &filename )); + bool Load(); // Standard values and informations contained in the header bool IsReadable(); // Some heuristic based accessors, end user intended + int GetImageNumber(); + ModalityType GetModality(); + + int GetXSize(); + int GetYSize(); + int GetZSize(); + + float GetXSpacing(); + float GetYSpacing(); + float GetZSpacing(); + + float GetXOrigin(); + float GetYOrigin(); + float GetZOrigin(); + + bool GetImageOrientationPatient( float iop[6] ); + int GetBitsStored(); int GetBitsAllocated(); + int GetHighBitPosition(); int GetSamplesPerPixel(); int GetPlanarConfiguration(); int GetPixelSize(); - int GetHighBitPosition(); + std::string GetPixelType(); bool IsSignedPixelData(); bool IsMonochrome(); + bool IsMonochrome1(); bool IsPaletteColor(); bool IsYBRFull(); - std::string GetPixelType(); - size_t GetPixelOffset(); - size_t GetPixelAreaLength(); - - //Some image informations needed for third package imaging library - int GetXSize(); - int GetYSize(); - int GetZSize(); - - float GetXSpacing(); - float GetYSpacing(); - float GetZSpacing(); + bool HasLUT(); + int GetLUTNbits(); - // Useful for rescaling graylevel: + // For rescaling graylevel: float GetRescaleIntercept(); float GetRescaleSlope(); int GetNumberOfScalarComponents(); int GetNumberOfScalarComponentsRaw(); - int GetImageNumber(); - ModalityType GetModality(); - - float GetXOrigin(); - float GetYOrigin(); - float GetZOrigin(); - - bool HasLUT(); - int GetLUTNbits(); - /// Accessor to \ref File::GrPixel uint16_t GetGrPixel() { return GrPixel; } - /// Accessor to \ref File::NumPixel uint16_t GetNumPixel() { return NumPixel; } + size_t GetPixelOffset(); + size_t GetPixelAreaLength(); + + /// returns the RLE info + RLEFramesInfo *GetRLEInfo() { return RLEInfo; } + /// Returns the JPEG Fragments info + JPEGFragmentsInfo *GetJPEGInfo() { return JPEGInfo; } + +// Anonymization process + void AddAnonymizeElement (uint16_t group, uint16_t elem, + std::string const &value); + /// Clears the list of elements to be anonymized + void ClearAnonymizeList() { UserAnonymizeList.clear(); } + void AnonymizeNoLoad(); + /// Replace patient's own information by info from the Anonymization list + bool AnonymizeFile(); + bool Write(std::string fileName, FileType filetype); - /// Initialize DICOM File when none - void InitializeDefaultFile(); - protected: - /// Replace patient's specific information by 'anonymous' - bool AnonymizeFile(); + + /// Store the RLE frames info obtained during parsing of pixels. + RLEFramesInfo *RLEInfo; + /// Store the JPEG fragments info obtained during parsing of pixels. + JPEGFragmentsInfo *JPEGInfo; - /// Helper function needed to organize DICOM files based on - /// their x,y,z position - void GetImageOrientationPatient( float iop[6] ); + /// \brief In some cases (e.g. for some ACR-NEMA images) the Entry Element + /// Number of the 'Pixel Element' is *not* found at 0x0010. In order to + /// make things easier the parser shall store the proper value in + /// NumPixel to provide a unique access facility. + uint16_t NumPixel; + /// \brief In some cases (e.g. for some ACR-NEMA images) the header entry for + /// the group of pixels is *not* found at 0x7fe0. + /// In order to make things easier the parser shall store the proper value + /// in GrPixel to provide a unique access facility. + uint16_t GrPixel; private: - friend class SerieHeader; + bool DoTheLoadingJob(); + void ComputeRLEInfo(); + void ComputeJPEGFragmentInfo(); + bool ReadTag(uint16_t, uint16_t); + uint32_t ReadTagLength(uint16_t, uint16_t); + void ReadEncapsulatedBasicOffsetTable(); + uint32_t *BasicOffsetTableItemValue; + }; } // end namespace gdcm