X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmRLEFramesInfo.h;h=dfabdf4bffc554a0f96fd88837f8b2582e06279f;hb=4ae5f29bc5a2fa48c38fe43d331e5099aad4ed0f;hp=f712f959a140b76f777c3243b6d8c762fef8a1a2;hpb=2bb60efea83f2bfa1823f27b2a5536a0e6cfd8c0;p=gdcm.git diff --git a/src/gdcmRLEFramesInfo.h b/src/gdcmRLEFramesInfo.h index f712f959..dfabdf4b 100644 --- a/src/gdcmRLEFramesInfo.h +++ b/src/gdcmRLEFramesInfo.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmRLEFramesInfo.h,v $ Language: C++ - Date: $Date: 2004/12/03 10:21:54 $ - Version: $Revision: 1.7 $ + Date: $Date: 2007/08/22 16:14:04 $ + Version: $Revision: 1.24 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -17,14 +17,15 @@ =========================================================================*/ -#ifndef GDCMRLEFRAMESINFO_H -#define GDCMRLEFRAMESINFO_H +#ifndef _GDCMRLEFRAMESINFO_H_ +#define _GDCMRLEFRAMESINFO_H_ #include "gdcmRLEFrame.h" + #include -namespace gdcm -{ +namespace GDCM_NAME_SPACE +{ /** * \brief Utility class for gathering the informations of the collection * of RLE frame[s] (see \ref RLEFrame) when handling @@ -32,23 +33,35 @@ namespace gdcm * Note: a classical image can be considered as the degenerated case * of a multiframe image. In this case the collection is limited * to a single individual frame. - * The informations on each frame are obtained during the parsing - * of a Document (refer to - * \ref Document::ComputeRLEInfo() ). + * The informations on each frame are obtained during the pixel parsing + * of a gdcm::File (refer to + * \ref File::ComputeRLEInfo() ). * They shall be used when (if necessary) decoding the frames. * * This class is simply a stl list<> of \ref RLEFrame. */ class GDCM_EXPORT RLEFramesInfo { - typedef std::list< RLEFrame* > RLEFrameList; -friend class Document; -friend class File; friend class PixelReadConvert; - RLEFrameList Frames; -public: +friend class File; + +private: ~RLEFramesInfo(); - void Print( std::string indent = "", std::ostream &os = std::cout ); + void Print( std::ostream &os = std::cout, std::string indent = "" ); + bool DecompressRLEFile( std::ifstream *fp, uint8_t *subRaw, int xSize, + int ySize, int zSize, int tSize, int bitsAllocated ); + bool ConvertRLE16BitsFromRLE8Bits( uint8_t *subRaw, int xSize, int ySize, + int tSize, int numberOfFrames); + + void AddFrame(RLEFrame *frame); + + RLEFrame *GetFirstFrame(); + RLEFrame *GetNextFrame(); + + typedef std::list RLEFrameList; + + RLEFrameList Frames; + RLEFrameList::iterator ItFrames; }; } // end namespace gdcm