/usr/include/gdcm-2.0/gdcmJPEGCodec.h is in libgdcm2-dev 2.0.18-7.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 | /*=========================================================================
Program: GDCM (Grassroots DICOM). A DICOM library
Copyright (c) 2006-2011 Mathieu Malaterre
All rights reserved.
See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
#ifndef GDCMJPEGCODEC_H
#define GDCMJPEGCODEC_H
#include "gdcmImageCodec.h"
namespace gdcm
{
class PixelFormat;
class TransferSyntax;
/**
* \brief JPEG codec
* Class to do JPEG (8bits, 12bits, 16bits lossy & lossless).
* It redispatch in between the different codec implementation: gdcm::JPEG8Codec,
* gdcm::JPEG12Codec & gdcm::JPEG16Codec
* It also support inconsistency in between DICOM header and JPEG compressed stream
* ImageCodec implementation for the JPEG case
*
* \note
* Things you should know if you ever want to dive into DICOM/JPEG world (among other):
*
* - http://groups.google.com/group/comp.protocols.dicom/browse_thread/thread/625e46919f2080e1
* - http://groups.google.com/group/comp.protocols.dicom/browse_thread/thread/75fdfccc65a6243
* - http://groups.google.com/group/comp.protocols.dicom/browse_thread/thread/2d525ef6a2f093ed
* - http://groups.google.com/group/comp.protocols.dicom/browse_thread/thread/6b93af410f8c921f
*/
class GDCM_EXPORT JPEGCodec : public ImageCodec
{
public:
JPEGCodec();
~JPEGCodec();
bool CanDecode(TransferSyntax const &ts) const;
bool CanCode(TransferSyntax const &ts) const;
bool Decode(DataElement const &is, DataElement &os);
void SetPixelFormat(PixelFormat const &pf);
/// Compute the offset table:
void ComputeOffsetTable(bool b);
/// Compress into JPEG
bool Code(DataElement const &in, DataElement &out);
virtual bool GetHeaderInfo(std::istream &is, TransferSyntax &ts);
//void SetReversible(bool res);
void SetQuality(double q);
double GetQuality() const;
void SetLossless(bool l);
bool GetLossless() const;
protected:
bool Decode(std::istream &is, std::ostream &os);
bool IsValid(PhotometricInterpretation const &pi);
protected:
// Internal method called by SetPixelFormat
// Instantiate the right jpeg codec (8, 12 or 16)
void SetBitSample(int bit);
protected:
int BitSample;
bool Lossless;
int Quality;
private:
void SetupJPEGBitCodec(int bit);
JPEGCodec *Internal;
};
} // end namespace gdcm
#endif //GDCMJPEGCODEC_H
|