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

📄 dvpscu.h

📁 转化为DIB位图再显示出来的dicom文件C++代码
💻 H
字号:
/* * *  Copyright (C) 1998-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: dcmpstat * *  Author: Marco Eichelberg * *  Purpose: *    classes: DVPSCurve * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:03:37 $ *  CVS/RCS Revision: $Revision: 1.6 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef __DVPSCU_H__#define __DVPSCU_H__#include "dcmtk/config/osconfig.h"    /* make sure OS specific configuration is included first */#include "dcmtk/dcmpstat/dvpstyp.h"#include "dcmtk/ofstd/ofstring.h"#include "dcmtk/dcmdata/dctypes.h"#include "dcmtk/dcmdata/dcerror.h"class DcmItem;class OFConsole;/** the representation of one Curve in a DICOM image. */  class DVPSCurve{public:  /// default constructor  DVPSCurve();    /// copy constructor  DVPSCurve(const DVPSCurve& copy);  /** clone method.   *  @return a pointer to a new DVPSCurve object containing   *  a copy of this object.   */  DVPSCurve *clone() { return new DVPSCurve(*this); }  /// destructor  virtual ~DVPSCurve();  /** reads a curve from a DICOM dataset.   *  The DICOM elements of the Graphic Object item are copied   *  from the dataset to this object.   *  The completeness of the curve (presence of all required elements,   *  value multiplicity) is checked.   *  If this method returns an error code, the object is in undefined state afterwards.   *  @param dset the DICOM dataset from which the data is to be read   *  @param group lower byte of the curve repeating group to be read   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition read(DcmItem &dset, Uint8 group);  /** get group number of curve repeating group managed by this object.   *  @return the lower byte of the curve group   */  Uint8 getCurveGroup() { return curveGroup; }  /** gets the number of points in the curve.   *  @return number of points   */  size_t getNumberOfPoints() { return numberOfPoints; }  /** gets the type of data in the curve (ROI or POLY).   *  @return type of data in curve   */  DVPSCurveType getTypeOfData() { return typeOfData; }  /** gets one point from the curve data.   *  @param idx index of the curve point, must be < getNumberOfPoints();   *  @param x upon success the x value of the point is returned in this parameter   *  @param y upon success the y value of the point is returned in this parameter      *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition getPoint(size_t idx, double& x, double& y);  /** gets the curve description string if present.   *  If the description string is absent, this method returns NULL or an empty string.   *  @return curve description   */  const char *getCurveDescription() { return curveDescription.c_str(); }  /** gets the curve label string if present.   *  If the label string is absent, this method returns NULL or an empty string.   *  @return curve label   */  const char *getCurveLabel() { return curveLabel.c_str(); }  /** gets the curve axis units string for the X dimension if present.   *  If the string is absent, this method returns NULL or an empty string.   *  @return curve description   */  const char *getCurveAxisUnitsX() { return axisUnitsX.c_str(); }  /** gets the curve axis units string for the Y dimension if present.   *  If the string is absent, this method returns NULL or an empty string.   *  @return curve description   */  const char *getCurveAxisUnitsY() { return axisUnitsY.c_str(); }    /** sets a new log stream   *  @param stream new log stream, NULL for default logstream   *  @param verbMode verbose mode flag   *  @param dbgMode debug mode flag   */  void setLog(OFConsole *stream, OFBool verbMode, OFBool dbgMode);private:  /// private undefined assignment operator  DVPSCurve& operator=(const DVPSCurve&);    /// lower byte of the curve repeating group managed by this object  Uint8 curveGroup;  /// number of points in curve data  size_t numberOfPoints;  /// type of curve data  DVPSCurveType typeOfData;  /// curve data, converted to double  double *curveData;  /// curve data description if present  OFString curveDescription;  /// curve label if present  OFString curveLabel;  /// axis units X if present  OFString axisUnitsX;  /// axis units Y if present  OFString axisUnitsY;  /** output stream for error messages, never NULL   */  OFConsole *logstream;  /** flag indicating whether we're operating in verbose mode   */  OFBool verboseMode;     /** flag indicating whether we're operating in debug mode   */  OFBool debugMode;};#endif/* *  $Log: dvpscu.h,v $ *  Revision 1.6  2005/12/08 16:03:37  meichel *  Changed include path schema for all DCMTK header files * *  Revision 1.5  2001/09/26 15:36:09  meichel *  Adapted dcmpstat to class OFCondition * *  Revision 1.4  2001/06/01 15:50:13  meichel *  Updated copyright header * *  Revision 1.3  2000/06/02 16:00:44  meichel *  Adapted all dcmpstat classes to use OFConsole for log and error output * *  Revision 1.2  2000/03/08 16:28:50  meichel *  Updated copyright header. * *  Revision 1.1  1998/12/22 17:57:04  meichel *  Implemented Presentation State interface for overlays, *    VOI LUTs, VOI windows, curves. Added test program that *    allows to add curve data to DICOM images. * * */

⌨️ 快捷键说明

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