X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmPixelReadConvert.h;h=6a329ff1b2012e2698b6058c304158768601c3f3;hb=f64c6a60dfa65993c5483e0df303dd86ee6623ce;hp=1372220154dbff8bb686a8cc16c668a835eb1d68;hpb=e8caac199c2683cb0f118c42c61dc6aec85b1eec;p=gdcm.git diff --git a/src/gdcmPixelReadConvert.h b/src/gdcmPixelReadConvert.h index 13722201..6a329ff1 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/01/16 04:50:42 $ - Version: $Revision: 1.11 $ + Date: $Date: 2005/02/15 18:12:35 $ + Version: $Revision: 1.19 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -26,7 +26,7 @@ namespace gdcm { -class Header; +class File; class RLEFramesInfo; class JPEGFragmentsInfo; @@ -40,48 +40,37 @@ public: PixelReadConvert(); virtual ~PixelReadConvert(); - //// Getter accessors: - uint8_t* GetRGB() { return RGB; } + 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; } + uint8_t *GetRaw() { return Raw; } size_t GetRawSize() { return RawSize; } - uint8_t* GetLutRGBA() { return LutRGBA; } + uint8_t *GetLutRGBA() { return LutRGBA; } - //// Predicates: + // Predicates: bool IsRawRGB(); - void Print( std::ostream &os = std::cout, std::string const & indent = "" ); - // In progress - void GrabInformationsFromHeader( Header *header ); + void GrabInformationsFromFile( File *file ); bool ReadAndDecompressPixelData( std::ifstream *fp ); void Squeeze(); bool BuildRGBImage(); private: // Use the fp: - bool ReadAndDecompressRLEFragment( - uint8_t *subDecompressed, - long fragmentSize, - long decompressedSegmentSize, - std::ifstream *fp ); - void ReadAndDecompress12BitsTo16Bits( std::ifstream *fp ) throw ( FormatError ); - bool ReadAndDecompressRLEFile( std::ifstream *fp ); + void ReadAndDecompress12BitsTo16Bits( std::ifstream *fp ) + throw ( FormatError ); bool ReadAndDecompressJPEGFile( std::ifstream *fp ); - bool ReadAndDecompressJPEGFramesFromFile( std::ifstream *fp ); - bool ReadAndDecompressJPEGSingleFrameFragmentsFromFile( std::ifstream *fp ); - bool ReadAndDecompressJPEGFragmentedFramesFromFile( std::ifstream *fp ); - - - void BuildLUTRGBA( std::ifstream *fp ); // In place (within Decompressed and with no fp access) decompression // or convertion: void BuildLUTRGBA(); - bool DecompressRLE16BitsFromRLE8Bits( int NumberOfFrames ); void ConvertSwapZone(); void ConvertReorderEndianity(); bool ConvertReArrangeBits() throw ( FormatError ); + void ConvertFixGreyLevels(); void ConvertRGBPlanesToRGBPixels(); void ConvertYcBcRPlanesToRGBPixels(); void ConvertHandleColor(); @@ -118,7 +107,10 @@ private: bool IsRaw; bool IsJPEG2000; + bool IsJPEGLS; bool IsJPEGLossless; + bool IsJPEGLossy; + bool IsJPEG; bool IsRLELossless; RLEFramesInfo *RLEInfo; @@ -127,6 +119,7 @@ private: // For handling color stage int PlanarConfiguration; bool IsMonochrome; + bool IsMonochrome1; bool IsPaletteColor; bool IsYBRFull; bool HasLUT;