⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dihsvpxt.h

📁 转化为DIB位图再显示出来的dicom文件C++代码
💻 H
字号:
/* * *  Copyright (C) 1996-2005, OFFIS * *  This software and supporting documentation were developed by * *    Kuratorium OFFIS e.V. *    Healthcare Information and Communication Systems *    Escherweg 2 *    D-26121 Oldenburg, Germany * *  THIS SOFTWARE IS MADE AVAILABLE,  AS IS,  AND OFFIS MAKES NO  WARRANTY *  REGARDING  THE  SOFTWARE,  ITS  PERFORMANCE,  ITS  MERCHANTABILITY  OR *  FITNESS FOR ANY PARTICULAR USE, FREEDOM FROM ANY COMPUTER DISEASES  OR *  ITS CONFORMITY TO ANY SPECIFICATION. THE ENTIRE RISK AS TO QUALITY AND *  PERFORMANCE OF THE SOFTWARE IS WITH THE USER. * *  Module:  dcmimage * *  Author:  Joerg Riesmeier * *  Purpose: DicomHSVPixelTemplate (Header) * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:01:39 $ *  CVS/RCS Revision: $Revision: 1.19 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef DIHSVPXT_H#define DIHSVPXT_H#include "dcmtk/config/osconfig.h"#include "dcmtk/ofstd/ofconsol.h"    /* for ofConsole */#include "dcmtk/dcmimage/dicopxt.h"#include "dcmtk/dcmimgle/diinpx.h"  /* gcc 3.4 needs this *//*---------------------* *  class declaration  * *---------------------*//** Template class to handle HSV pixel data */template<class T1, class T2>class DiHSVPixelTemplate  : public DiColorPixelTemplate<T2>{ public:    /** constructor     *     ** @param  docu       pointer to DICOM document     *  @param  pixel      pointer to input pixel representation     *  @param  status     reference to status variable     *  @param  planeSize  number of pixels in a plane     *  @param  bits       number of bits per sample     */    DiHSVPixelTemplate(const DiDocument *docu,                       const DiInputPixel *pixel,                       EI_Status &status,                       const unsigned long planeSize,                       const int bits)      : DiColorPixelTemplate<T2>(docu, pixel, 3, status)    {        if ((pixel != NULL) && (this->Count > 0) && (status == EIS_Normal))            convert(OFstatic_cast(const T1 *, pixel->getData()) + pixel->getPixelStart(), planeSize, bits);    }    /** destructor     */    virtual ~DiHSVPixelTemplate()    {    } private:    /** convert input pixel data to intermediate representation     *     ** @param  pixel      pointer to input pixel data     *  @param  planeSize  number of pixels in a plane     *  @param  bits       number of bits per sample     */    void convert(const T1 *pixel,                 const unsigned long planeSize,                 const int bits)    {        if (Init(pixel))        {            register T2 *r = this->Data[0];            register T2 *g = this->Data[1];            register T2 *b = this->Data[2];            const T2 maxvalue = OFstatic_cast(T2, DicomImageClass::maxval(bits));            const T1 offset = OFstatic_cast(T1, DicomImageClass::maxval(bits - 1));            // 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;            if (this->PlanarConfiguration)            {/*                register const T1 *h = pixel;                register const T1 *s = h + this->InputCount;                register const T1 *v = s + this->InputCount;                for (i = count; i != 0; --i)                    convertValue(*(r++), *(g++), *(b++), removeSign(*(h++), offset), removeSign(*(s++), offset),                        removeSign(*(v++), offset), maxvalue);*/                register unsigned long l;                register unsigned long i = count;                register const T1 *h = pixel;                register const T1 *s = h + planeSize;                register const T1 *v = s + planeSize;                while (i != 0)                {                    /* convert a single frame */                    for (l = planeSize; (l != 0) && (i != 0); --l, --i)                    {                        convertValue(*(r++), *(g++), *(b++), removeSign(*(h++), offset), removeSign(*(s++), offset),                            removeSign(*(v++), offset), maxvalue);                    }                    /* jump to next frame start (skip 2 planes) */                    h += 2 * planeSize;                    s += 2 * planeSize;                    v += 2 * planeSize;                }            }            else            {                register const T1 *p = pixel;                register T2 h;                register T2 s;                register T2 v;                register unsigned long i;                for (i = count; i != 0; --i)                {                    h = removeSign(*(p++), offset);                    s = removeSign(*(p++), offset);                    v = removeSign(*(p++), offset);                    convertValue(*(r++), *(g++), *(b++), h, s, v, maxvalue);                }            }        }    }    /** convert a single HSV value to RGB     */    void convertValue(T2 &red,                      T2 &green,                      T2 &blue,                      const T2 hue,                      const T2 saturation,                      const T2 value,                      const T2 maxvalue)    {        /*         *   conversion algorithm taken from Foley et al.: 'Computer Graphics: Principles and Practice' (1990)         */        if (saturation == 0)        {            red = value;            green = value;            blue = value;        }        else        {            const double h = (OFstatic_cast(double, hue) * 6) / (OFstatic_cast(double, maxvalue) + 1);  // '... + 1' to assert h < 6            const double s = OFstatic_cast(double, saturation) / OFstatic_cast(double, maxvalue);            const double v = OFstatic_cast(double, value) / OFstatic_cast(double, maxvalue);            const T2 hi = OFstatic_cast(T2, h);            const double hf = h - hi;            const T2 p = OFstatic_cast(T2, maxvalue * v * (1 - s));            const T2 q = OFstatic_cast(T2, maxvalue * v * (1 - s * hf));            const T2 t = OFstatic_cast(T2, maxvalue * v * (1 - s * (1 - hf)));            switch (hi)            {                case 0:                    red = value;                    green = t;                    blue = p;                    break;                case 1:                    red = q;                    green = value;                    blue = p;                    break;                case 2:                    red = p;                    green = value;                    blue = t;                    break;                case 3:                    red = p;                    green = q;                    blue = value;                    break;                case 4:                    red = t;                    green = p;                    blue = value;                    break;                case 5:                    red = value;                    green = p;                    blue = q;                    break;                default:                    if (DicomImageClass::checkDebugLevel(DicomImageClass::DL_Warnings))                    {                        ofConsole.lockCerr() << "WARNING: invalid value for 'hi' while converting HSV to RGB !" << endl;                        ofConsole.unlockCerr();                    }            }        }    }};#endif/* * * CVS/RCS Log: * $Log: dihsvpxt.h,v $ * Revision 1.19  2005/12/08 16:01:39  meichel * Changed include path schema for all DCMTK header files * * Revision 1.18  2004/04/21 10:00:31  meichel * Minor modifications for compilation with gcc 3.4.0 * * Revision 1.17  2003/12/23 11:48:23  joergr * Adapted type casts to new-style typecast operators defined in ofcast.h. * Removed leading underscore characters from preprocessor symbols (reserved * symbols). Updated copyright header. * Replaced post-increment/decrement operators by pre-increment/decrement * operators where appropriate (e.g. 'i++' by '++i'). * * Revision 1.16  2002/06/26 16:18:10  joergr * Enhanced handling of corrupted pixel data and/or length. * Corrected decoding of multi-frame, planar images. * * Revision 1.15  2001/11/09 16:47:01  joergr * Removed 'inline' specifier from certain methods. * * Revision 1.14  2001/06/01 15:49:30  meichel * Updated copyright header * * Revision 1.13  2000/04/28 12:39:32  joergr * DebugLevel - global for the module - now derived from OFGlobal (MF-safe). * * Revision 1.12  2000/04/27 13:15:13  joergr * Dcmimage library code now consistently uses ofConsole for error output. * * Revision 1.11  2000/03/08 16:21:52  meichel * Updated copyright header. * * Revision 1.10  2000/03/03 14:07:52  meichel * Implemented library support for redirecting error messages into memory *   instead of printing them to stdout/stderr for GUI applications. * * Revision 1.9  1999/09/17 14:03:45  joergr * Enhanced efficiency of some "for" loops. * * Revision 1.8  1999/04/28 12:47:04  joergr * Introduced new scheme for the debug level variable: now each level can be * set separately (there is no "include" relationship). * * Revision 1.7  1999/02/03 16:54:27  joergr * Moved global functions maxval() and determineRepresentation() to class * DicomImageClass (as static methods). * * Revision 1.6  1999/01/20 14:46:15  joergr * Replaced invocation of getCount() by member variable Count where possible. * * Revision 1.5  1998/11/27 13:51:50  joergr * Added copyright message. * * Revision 1.4  1998/05/11 14:53:16  joergr * Added CVS/RCS header to each file. * * */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -