/usr/include/dcmtk/dcmimage/diqtcmap.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 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 | /*
*
* 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: dcmimage
*
* Author: Marco Eichelberg
*
* Purpose: class DcmQuantColorMapping
*
*/
#ifndef DIQTCMAP_H
#define DIQTCMAP_H
#include "dcmtk/config/osconfig.h"
#include "dcmtk/dcmimage/diqttype.h" /* for DcmQuantComponent */
#include "dcmtk/dcmimgle/dcmimage.h" /* gcc 3.4 needs this */
#include "dcmtk/dcmimage/diqtstab.h" /* gcc 3.4 needs this */
#include "dcmtk/dcmimage/diqtpix.h" /* gcc 3.4 needs this */
#include "dcmtk/dcmimage/diqthash.h" /* gcc 3.4 needs this */
#include "dcmtk/dcmimage/diqtctab.h" /* gcc 3.4 needs this */
class DicomImage;
class DcmQuantColorHashTable;
class DcmQuantColorTable;
class DcmQuantPixel;
class DcmQuantScaleTable;
/** template class that maps a color image into a palette color image
* with given color palette. The two template parameters define the
* error diffusion class used to implement e.g. Floyd-Steinberg error
* diffusion and the output type of the color index values, which may be
* 8 bit or 16 bit unsigned integers.
*/
template <class T1, class T2>
class DcmQuantColorMapping
{
public:
/** converts a single frame of a color image into a palette color image.
* @param sourceImage color image
* @param frameNumber number of frame (in sourceImage) that is converted
* @param maxval maximum pixel value to which all color samples
* were down-sampled during computation of the histogram on which
* the color LUT is based. This value is required to make sure that the
* hash table doesn't get too large.
* @param cht color hash table. This table is passed by the caller since
* the same hash table can be used if multiple frames are converted.
* Initially (i.e. when called for the first frame) the hash table is empty.
* @param colormap color LUT to which the color image is mapped.
* @param fs error diffusion object, e.g. an instance of class DcmQuantIdent
* or class DcmQuantFloydSteinberg, depending on the template instantiation.
* @param tp pointer to an array to which the palette color image data
* is written. The array must be large enough to store sourceImage.getWidth()
* times sourceImage.getHeight() values of type T2.
*/
static void create(
DicomImage& sourceImage,
unsigned long frameNumber,
unsigned long maxval,
DcmQuantColorHashTable& cht,
DcmQuantColorTable& colormap,
T1& fs,
T2 *tp)
{
unsigned long cols = sourceImage.getWidth();
unsigned long rows = sourceImage.getHeight();
const int bits = sizeof(DcmQuantComponent)*8;
DcmQuantPixel px;
long limitcol;
long col; // must be signed!
long maxval_l = OFstatic_cast(long, maxval);
register int ind;
const DcmQuantComponent *currentpixel;
register DcmQuantComponent cr, cg, cb;
// create scale table
DcmQuantScaleTable scaletable;
scaletable.createTable(OFstatic_cast(DcmQuantComponent, -1), maxval);
const void *data = sourceImage.getOutputData(bits, frameNumber, 0);
if (data)
{
const DcmQuantComponent *cp = OFstatic_cast(const DcmQuantComponent *, data);
for (unsigned long row = 0; row < rows; ++row)
{
fs.startRow(col, limitcol);
do
{
currentpixel = cp + col + col + col;
cr = *currentpixel++;
cg = *currentpixel++;
cb = *currentpixel;
px.scale(cr, cg, cb, scaletable);
fs.adjust(px, col, maxval_l);
// Check hash table to see if we have already matched this color.
ind = cht.lookup(px);
if (ind < 0)
{
ind = colormap.computeIndex(px);
cht.add(px, ind);
}
fs.propagate(px, colormap.getPixel(ind), col);
tp[col] = OFstatic_cast(T2, ind);
fs.nextCol(col);
} while ( col != limitcol );
fs.finishRow();
cp += (cols * 3); // advance source pointer by one row
tp += cols; // advance target pointer by one row
} // for all rows
} // if (data)
}
};
#endif
|