X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmPixelReadConvert.h;h=4c6f96c0d824ed766e6b4dc9f3cfe09d96f68aa3;hb=066996143ee597cc94ffc6d27751301931afad30;hp=29a5b12dd4f6c8be3e83b6232377900cb5b0dae4;hpb=96cc99e8e141ceaf026104699c3273ad5fc88a1f;p=gdcm.git diff --git a/src/gdcmPixelReadConvert.h b/src/gdcmPixelReadConvert.h index 29a5b12d..4c6f96c0 100644 --- a/src/gdcmPixelReadConvert.h +++ b/src/gdcmPixelReadConvert.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmPixelReadConvert.h,v $ Language: C++ - Date: $Date: 2005/02/03 10:03:07 $ - Version: $Revision: 1.18 $ + Date: $Date: 2005/06/17 12:35:00 $ + Version: $Revision: 1.23 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -20,9 +20,9 @@ #ifndef GDCMPIXELREADCONVERT_H #define GDCMPIXELREADCONVERT_H -#include "gdcmCommon.h" #include "gdcmBase.h" #include "gdcmException.h" +#include namespace gdcm { @@ -43,12 +43,13 @@ public: void Print( std::ostream &os = std::cout, std::string const &indent = "" ); // Getter accessors: - uint8_t *GetRGB() { return RGB; } - size_t GetRGBSize() { return RGBSize; } - uint8_t *GetRaw() { return Raw; } - size_t GetRawSize() { return RawSize; } - uint8_t *GetLutRGBA() { return LutRGBA; } - + uint8_t *GetRGB() { return RGB; } + size_t GetRGBSize() { return RGBSize; } + uint8_t *GetRaw() { return Raw; } + size_t GetRawSize() { return RawSize; } + uint8_t *GetLutRGBA() { return LutRGBA; } + int GetLutItemNumber() { return LutItemNumber; } + int GetLutItemSize() { return LutItemSize; } // Predicates: bool IsRawRGB(); @@ -57,6 +58,7 @@ public: bool ReadAndDecompressPixelData( std::ifstream *fp ); void Squeeze(); bool BuildRGBImage(); + void BuildLUTRGBA(); private: // Use the fp: @@ -66,10 +68,10 @@ private: // In place (within Decompressed and with no fp access) decompression // or convertion: - void BuildLUTRGBA(); void ConvertSwapZone(); void ConvertReorderEndianity(); bool ConvertReArrangeBits() throw ( FormatError ); + void ConvertFixGreyLevels(); void ConvertRGBPlanesToRGBPixels(); void ConvertYcBcRPlanesToRGBPixels(); void ConvertHandleColor(); @@ -79,7 +81,11 @@ private: void AllocateRaw(); // Variables - /// Pixel data represented as RGB after LUT color interpretation. +/** + * \brief Pixel data represented as RGB after LUT color interpretation. + * 'uint8_t' is just to avoid warnings at compile time. + * feel free to cast it as uint16_t if you need + */ uint8_t *RGB; /// Size of RGB image. size_t RGBSize; @@ -90,6 +96,11 @@ private: /// \brief Red/Green/Blue/Alpha LookUpTable build out of the /// Red/Green/Blue LUT descriptors (see \ref BuildLUTRGBA ). uint8_t *LutRGBA; + int LutItemNumber; + int LutItemSize; + + // *ALL* the following info belong to the FileHelper + // One should think there is an analyze error in the model ! size_t PixelOffset; size_t PixelDataLength; @@ -111,6 +122,7 @@ private: bool IsJPEGLossy; bool IsJPEG; bool IsRLELossless; + bool IsMPEG; RLEFramesInfo *RLEInfo; JPEGFragmentsInfo *JPEGInfo; @@ -118,6 +130,7 @@ private: // For handling color stage int PlanarConfiguration; bool IsMonochrome; + bool IsMonochrome1; bool IsPaletteColor; bool IsYBRFull; bool HasLUT; @@ -128,7 +141,6 @@ private: uint8_t *LutRedData; uint8_t *LutGreenData; uint8_t *LutBlueData; - }; } // end namespace gdcm