Module: $RCSfile: gdcmFileHelper.cxx,v $
Language: C++
- Date: $Date: 2005/05/27 10:51:00 $
- Version: $Revision: 1.42 $
+ Date: $Date: 2005/06/17 12:35:00 $
+ Version: $Revision: 1.43 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
*/
uint8_t* FileHelper::GetLutRGBA()
{
+ if ( PixelReadConverter->GetLutRGBA() ==0 )
+ PixelReadConverter->BuildLUTRGBA();
return PixelReadConverter->GetLutRGBA();
}
+/**
+ * \brief Access to the underlying \ref PixelReadConverter RGBA LUT Item Number
+ */
+int FileHelper::GetLutItemNumber()
+{
+ return PixelReadConverter->GetLutItemNumber();
+}
+
+/**
+ * \brief Access to the underlying \ref PixelReadConverter RGBA LUT Item Size
+ */
+int FileHelper::GetLutItemSize()
+{
+ return PixelReadConverter->GetLutItemSize();
+}
+
/**
* \brief Writes on disk A SINGLE Dicom file
* NO test is performed on processor "Endiannity".
Program: gdcm
Module: $RCSfile: gdcmFileHelper.h,v $
Language: C++
- Date: $Date: 2005/03/09 09:45:33 $
- Version: $Revision: 1.16 $
+ Date: $Date: 2005/06/17 12:35:00 $
+ Version: $Revision: 1.17 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
// LUT
uint8_t* GetLutRGBA();
+ int GetLutItemNumber();
+ int GetLutItemSize();
// Write mode
Program: gdcm
Module: $RCSfile: gdcmPixelReadConvert.cxx,v $
Language: C++
- Date: $Date: 2005/06/15 19:59:39 $
- Version: $Revision: 1.66 $
+ Date: $Date: 2005/06/17 12:35:00 $
+ Version: $Revision: 1.67 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
LutRGBA = new uint8_t[ 1024 ]; // 256 * 4 (R, G, B, Alpha)
if ( !LutRGBA )
return;
-
+ LutItemNumber = 256;
+ LutItemSize = 8;
memset( LutRGBA, 0, 1024 );
int mult;
return;
memset( LutRGBA, 0, 65536*4*2 ); // 16 bits = 2 bytes ;-)
+ LutItemNumber = 65536;
+ LutItemSize = 16;
+
int i;
uint16_t *a16;
a16 = (uint16_t*)LutRGBA + 0 + debR;
for( i=0; i < lengthR; ++i )
{
- *a16 = ((uint16_t*)LutRedData)[i+1];
+ *a16 = ((uint16_t*)LutRedData)[i];
a16 += 4;
}
a16 = (uint16_t*)LutRGBA + 1 + debG;
for( i=0; i < lengthG; ++i)
{
- *a16 = ((uint16_t*)LutGreenData)[i+1];
+ *a16 = ((uint16_t*)LutGreenData)[i];
a16 += 4;
}
a16 = (uint16_t*)LutRGBA + 2 + debB;
for(i=0; i < lengthB; ++i)
{
- *a16 = ((uint16_t*)LutBlueData)[i+1];
+ *a16 = ((uint16_t*)LutBlueData)[i];
a16 += 4;
}
*/
void PixelReadConvert::ConvertYcBcRPlanesToRGBPixels()
{
+ // Remarks for YBR newbees :
+ // YBR_FULL works very much like RGB, i.e. three samples per pixel,
+ // just the color space is YCbCr instead of RGB. This is particularly useful
+ // for doppler ultrasound where most of the image is grayscale
+ // (i.e. only populates the Y components) and Cb and Cr are mostly zero,
+ // except for the few patches of color on the image. //
+ // On such images, RLE achieves a compression ratio that is much better
+ // than the compression ratio on an equivalent RGB image.
+
uint8_t *localRaw = Raw;
uint8_t *copyRaw = new uint8_t[ RawSize ];
memmove( copyRaw, localRaw, RawSize );
Program: gdcm
Module: $RCSfile: gdcmPixelReadConvert.h,v $
Language: C++
- Date: $Date: 2005/06/14 13:56:42 $
- Version: $Revision: 1.22 $
+ 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
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();
bool ReadAndDecompressPixelData( std::ifstream *fp );
void Squeeze();
bool BuildRGBImage();
+ void BuildLUTRGBA();
private:
// Use the fp:
// In place (within Decompressed and with no fp access) decompression
// or convertion:
- void BuildLUTRGBA();
void ConvertSwapZone();
void ConvertReorderEndianity();
bool ConvertReArrangeBits() throw ( FormatError );
/// \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;
uint8_t *LutRedData;
uint8_t *LutGreenData;
uint8_t *LutBlueData;
-
};
} // end namespace gdcm