/usr/include/dcmtk/dcmimage/dipalpxt.h is in libdcmtk-dev 3.6.1~20150924-5.
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 | /*
*
* Copyright (C) 1996-2011, 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: dcmimage
*
* Author: Joerg Riesmeier
*
* Purpose: DicomPalettePixelTemplate (Header)
*
*/
#ifndef DIPALPXT_H
#define DIPALPXT_H
#include "dcmtk/config/osconfig.h"
#include "dcmtk/dcmimage/dicopxt.h"
#include "dcmtk/dcmimgle/diluptab.h"
#include "dcmtk/dcmimgle/diinpx.h" /* gcc 3.4 needs this */
/*---------------------*
* class declaration *
*---------------------*/
/** Template class to handle Palette color pixel data
*/
template<class T1, class T2, class T3>
class DiPalettePixelTemplate
: public DiColorPixelTemplate<T3>
{
public:
/** constructor
*
** @param docu pointer to DICOM document
* @param pixel pointer to input pixel representation
* @param palette pointer to RGB color palette
* @param status reference to status variable
*/
DiPalettePixelTemplate(const DiDocument *docu,
const DiInputPixel *pixel,
DiLookupTable *palette[3],
EI_Status &status)
: DiColorPixelTemplate<T3>(docu, pixel, 1, status)
{
if ((pixel != NULL) && (this->Count > 0) && (status == EIS_Normal))
{
if (this->PlanarConfiguration)
{
status = EIS_InvalidValue;
DCMIMAGE_ERROR("invalid value for 'PlanarConfiguration' (" << this->PlanarConfiguration << ")");
}
else
convert(OFstatic_cast(const T1 *, pixel->getData()) + pixel->getPixelStart(), palette);
}
}
/** destructor
*/
virtual ~DiPalettePixelTemplate()
{
}
private:
/** convert input pixel data to intermediate representation
*
** @param pixel pointer to input pixel data
* @param palette pointer to RGB color palette
*/
void convert(const T1 *pixel,
DiLookupTable *palette[3])
{ // can be optimized if necessary !
if (this->Init(pixel))
{
register const T1 *p = pixel;
register T2 value = 0;
register unsigned long i;
register int j;
// use the number of input pixels derived from the length of the 'PixelData'
// attribute), but not more than the size of the intermediate buffer
const unsigned long count = (this->InputCount < this->Count) ? this->InputCount : this->Count;
for (i = 0; i < count; ++i)
{
value = OFstatic_cast(T2, *(p++));
for (j = 0; j < 3; ++j)
{
if (value <= palette[j]->getFirstEntry(value))
this->Data[j][i] = OFstatic_cast(T3, palette[j]->getFirstValue());
else if (value >= palette[j]->getLastEntry(value))
this->Data[j][i] = OFstatic_cast(T3, palette[j]->getLastValue());
else
this->Data[j][i] = OFstatic_cast(T3, palette[j]->getValue(value));
}
}
}
}
};
#endif
|