X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmPixelReadConvert.h;h=4aac9d3d3bdf83a663f2a9f1d87ef216564cf3f2;hb=b08873f37c7696af28217a92f2ee41bf76e98a63;hp=5c34a043d2e86bbc12816ec99d53f2d7964b5bb0;hpb=58c14d2a459b733b3bd18442cfbb2c92ea77d1dd;p=gdcm.git diff --git a/src/gdcmPixelReadConvert.h b/src/gdcmPixelReadConvert.h index 5c34a043..4aac9d3d 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/07/30 18:27:00 $ - Version: $Revision: 1.24 $ + Date: $Date: 2005/10/23 15:09:19 $ + Version: $Revision: 1.26 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -40,19 +40,28 @@ typedef void (*VOID_FUNCTION_PUINT8_PFILE_POINTER)(uint8_t *, File *); */ class GDCM_EXPORT PixelReadConvert : public Base { -public: +friend class FileHelper; + +private: PixelReadConvert(); virtual ~PixelReadConvert(); void Print( std::ostream &os = std::cout, std::string const &indent = "" ); // Getter accessors: + /// \brief returns pixel area holding RGB Pixels, made from Grey level + LUT uint8_t *GetRGB() { return RGB; } + /// \brief returns pixel area length -RGB Pixels, (from Grey level + LUT)- size_t GetRGBSize() { return RGBSize; } + /// \brief returns pixel area holding native RGB Pixels or Grey level uint8_t *GetRaw() { return Raw; } + /// \brief returns pixel area size -native RGB Pixels or Grey level- size_t GetRawSize() { return RawSize; } + /// \brief returns Red Green Blue Alpha LUT uint8_t *GetLutRGBA() { return LutRGBA; } + /// \brief returns Lut Item Number int GetLutItemNumber() { return LutItemNumber; } + /// \brief returns Lut Item Size int GetLutItemSize() { return LutItemSize; } // Predicates: bool IsRawRGB(); @@ -63,10 +72,11 @@ public: void Squeeze(); bool BuildRGBImage(); void BuildLUTRGBA(); - +/// \brief Allow user to pass his own function to modify pixels +/// (e.g; mirror, upsidedown, ...) just after reading void SetUserFunction( VOID_FUNCTION_PUINT8_PFILE_POINTER userFunc ) { UserFunction = userFunc; } -private: + // Use the fp: void ReadAndDecompress12BitsTo16Bits( std::ifstream *fp ) throw ( FormatError ); @@ -122,6 +132,7 @@ private: int SwapCode; bool IsRaw; + bool IsPrivateGETransferSyntax; bool IsJPEG2000; bool IsJPEGLS; bool IsJPEGLossless;