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

📄 diqtstab.h

📁 转化为DIB位图再显示出来的dicom文件C++代码
💻 H
字号:
/* * *  Copyright (C) 2002-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:  Marco Eichelberg * *  Purpose: class DcmQuantScaleTable * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:01:54 $ *  CVS/RCS Revision: $Revision: 1.4 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef DIQTSTAB_H#define DIQTSTAB_H#include "dcmtk/config/osconfig.h"#include "dcmtk/ofstd/ofcast.h"#include "dcmtk/dcmimage/diqttype.h"  /* for DcmQuantComponent */#define INCLUDE_CSTDLIB#define INCLUDE_CASSERT#include "dcmtk/ofstd/ofstdinc.h"/** this is a helper class used for temporarily reducing the image bit depth *  during calculation of an image histogram.  An object of this class *  contains a look-up table that maps image pixel values to scaled-down *  image pixel values. */class DcmQuantScaleTable{public:  /// constructor  DcmQuantScaleTable()  : table(NULL)  , numEntries(0)  {  }  /// destructor  ~DcmQuantScaleTable()  {    cleanup();  }  /** array look-up operation.   *  @param idx pixel value to look up.  Object must be initialized   *    (i.e. createTable() must have been called before) and idx must   *    be less or equal to the parameter oldmaxval passed to createTable().   *  @return scaled-down value from look-up table.   */  inline DcmQuantComponent operator[](unsigned int idx) const  {#ifdef DEBUG  	assert(idx < numEntries);#endif  	return table[idx];  }  /** initializes the look-up table.   *  @param oldmaxval maximum possible pixel value in source image   *  @param newmaxval new desired maximum value, should be < oldmaxval   */  void createTable(    unsigned long oldmaxval,    unsigned long newmaxval)  {    cleanup();    table = new DcmQuantComponent[oldmaxval+1];    if (table)    {      numEntries = OFstatic_cast(unsigned int, oldmaxval) + 1;      for (unsigned int i=0; i < numEntries; i++)        table[i] = OFstatic_cast(DcmQuantComponent, (OFstatic_cast(unsigned long, i) * newmaxval + oldmaxval/2) / oldmaxval);    }  }private:  /// resets the object to the default-constructed state  inline void cleanup()  {    delete[] table;    table = NULL;    numEntries = 0;  }  /// private undefined copy constructor  DcmQuantScaleTable(const DcmQuantScaleTable& src);  /// private undefined copy assignment operator  DcmQuantScaleTable& operator=(const DcmQuantScaleTable& src);  /// array of pixel values  DcmQuantComponent *table;  /// number of entries in array  unsigned int numEntries;};#endif/* * CVS/RCS Log: * $Log: diqtstab.h,v $ * Revision 1.4  2005/12/08 16:01:54  meichel * Changed include path schema for all DCMTK header files * * Revision 1.3  2003/12/23 12:20:44  joergr * Adapted type casts to new-style typecast operators defined in ofcast.h. * Updated copyright header. * * Revision 1.2  2002/11/27 14:16:56  meichel * Adapted module dcmimage to use of new header file ofstdinc.h * * Revision 1.1  2002/01/25 13:32:07  meichel * Initial release of new color quantization classes and *   the dcmquant tool in module dcmimage. * * */

⌨️ 快捷键说明

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