/usr/include/dcmtk/dcmdata/dcrlecp.h is in libdcmtk-dev 3.6.1~20160216-4.
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 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 | /*
*
* Copyright (C) 2002-2014, OFFIS e.V.
* All rights reserved. See COPYRIGHT file for details.
*
* This software and supporting documentation were developed by
*
* OFFIS e.V.
* R&D Division Health
* Escherweg 2
* D-26121 Oldenburg, Germany
*
*
* Module: dcmdata
*
* Author: Marco Eichelberg
*
* Purpose: codec parameter for RLE
*
*/
#ifndef DCRLECP_H
#define DCRLECP_H
#include "dcmtk/config/osconfig.h"
#include "dcmtk/dcmdata/dccodec.h" /* for DcmCodecParameter */
/** codec parameter for RLE codec
*/
class DCMTK_DCMDATA_EXPORT DcmRLECodecParameter: public DcmCodecParameter
{
public:
/** constructor.
* @param pCreateSOPInstanceUID true if a new SOP instance UID should be assigned
* upon compression/decompression
* @param pFragmentSize maximum fragment size (in kbytes) for compression, 0 for unlimited.
* Please note that the DICOM standard does not allow for storing the pixel data with
* multiple fragments per frame (when RLE compression is used). So limiting the fragment
* size may result in non-standard conformant DICOM images.
* @param pCreateOffsetTable create offset table during image compression?
* @param pConvertToSC flag indicating whether image should be converted to
* Secondary Capture upon compression
* @param pReverseDecompressionByteOrder flag indicating whether the byte order should
* be reversed upon decompression. Needed to correctly decode some incorrectly encoded
* images with more than one byte per sample.
*/
DcmRLECodecParameter(
OFBool pCreateSOPInstanceUID = OFFalse,
Uint32 pFragmentSize = 0,
OFBool pCreateOffsetTable = OFTrue,
OFBool pConvertToSC = OFFalse,
OFBool pReverseDecompressionByteOrder = OFFalse);
/// copy constructor
DcmRLECodecParameter(const DcmRLECodecParameter& arg);
/// destructor
virtual ~DcmRLECodecParameter();
/** this methods creates a copy of type DcmCodecParameter *
* it must be overwritten in every subclass.
* @return copy of this object
*/
virtual DcmCodecParameter *clone() const;
/** returns the class name as string.
* can be used as poor man's RTTI replacement.
*/
virtual const char *className() const;
/** returns maximum fragment size (in kbytes) for compression, 0 for unlimited.
* @return maximum fragment size for compression
*/
Uint32 getFragmentSize() const
{
return fragmentSize;
}
/** returns offset table creation flag
* @return offset table creation flag
*/
OFBool getCreateOffsetTable() const
{
return createOffsetTable;
}
/** returns secondary capture conversion flag
* @return secondary capture conversion flag
*/
OFBool getConvertToSC() const
{
return convertToSC;
}
/** returns mode for SOP Instance UID creation
* @return mode for SOP Instance UID creation
*/
OFBool getUIDCreation() const
{
return createInstanceUID;
}
/** returns reverse decompression byte order mode
* @return reverse decompression byte order mode
*/
OFBool getReverseDecompressionByteOrder() const
{
return reverseDecompressionByteOrder;
}
private:
/// private undefined copy assignment operator
DcmRLECodecParameter& operator=(const DcmRLECodecParameter&);
/// maximum fragment size (in kbytes) for compression, 0 for unlimited.
Uint32 fragmentSize;
/// create offset table during image compression
OFBool createOffsetTable;
/// flag indicating whether image should be converted to Secondary Capture upon compression
OFBool convertToSC;
/// create new Instance UID during compression/decompression?
OFBool createInstanceUID;
/** enable reverse byte order of RLE segments during decompression, needed to
* decompress certain incorrectly encoded RLE images
*/
OFBool reverseDecompressionByteOrder;
};
#endif
|