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

📄 dvpssv.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: DVPSSoftcopyVOI * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:04:05 $ *  CVS/RCS Revision: $Revision: 1.6 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef __DVPSSV_H__#define __DVPSSV_H__#include "dcmtk/config/osconfig.h"    /* make sure OS specific configuration is included first */#include "dcmtk/ofstd/ofstring.h"#include "dcmtk/dcmdata/dctk.h"#include "dcmtk/dcmpstat/dvpsril.h"     /* for DVPSReferencedImage_PList */#include "dcmtk/dcmpstat/dvpstyp.h"     /* for enum types */class DVPSReferencedSeries_PList;/** the representation of one item of the Softcopy VOI LUT Sequence */  class DVPSSoftcopyVOI{public:  /// default constructor  DVPSSoftcopyVOI();    /// copy constructor  DVPSSoftcopyVOI(const DVPSSoftcopyVOI& copy);  /** clone method.   *  @return a pointer to a new DVPSSoftcopyVOI object containing   *  a copy of this object.   */  DVPSSoftcopyVOI *clone() { return new DVPSSoftcopyVOI(*this); }  /// destructor  virtual ~DVPSSoftcopyVOI();  /** reads a softcopy VOI LUT item from a DICOM dataset.   *  The DICOM elements of the softcopy VOI LUT item are copied   *  from the dataset to this object.   *  The completeness of the item (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 item of the SoftcopyVOILUTSequence from which the data is to be read   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition read(DcmItem &dset);    /** writes the dsoftcopy VOI LUT item managed by this object to a DICOM dataset.   *  Copies of the DICOM elements managed by this object are inserted into   *  the DICOM dataset.   *  @param dset the the item of the SoftcopyVOILUTSequence to which the data is written   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition write(DcmItem &dset);  /** checks if this displayed area is applicable to the given image and frame.   *  @param instanceUID SOP instance UID of the current image   *  @param frame number of the current frame   *  @return OFTrue if applicable.   */  OFBool isApplicable(const char *instanceUID, unsigned long frame);  /** checks if this displayed area matches exactly the applicability   *  defined by the instanceUID, frame and applicability parameters.   *  @param instanceUID SOP instance UID of the current image   *  @param frame number of the current frame   *  @return OFTrue if matching.   */  OFBool matchesApplicability(const char *instanceUID, unsigned long frame, DVPSObjectApplicability applicability);  /** add a new image reference.   *  Checks if the referenced SOP instance UID already exists in this sequence.   *  If it exists, an error code is returned. Otherwise a new image reference   *  is created and added to the ReferencedImageSequence.   *  @param sopclassUID the SOP class UID of the image reference to be added.   *  @param instanceUID the SOP instance UID of the image reference to be added.   *  @param frame the frame number of the image reference (current image) to be added.   *  @param applicability the applicability of the image reference (DVPSB_currentFrame or DVPSB_currentImage)   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition addImageReference(    const char *sopclassUID,    const char *instanceUID,     unsigned long frame,    DVPSObjectApplicability applicability);  /** removes a reference to an image or frame. If the current reference is empty ("global"), an   *  explicit list of references is constructed from the list of series/instance references.   *  The image or frame reference is removed from the total list of references in this object.   *  If the only reference contained in this object is removed, the reference list becomes empty   *  which means that the current reference becomes "global". This case must be handled by the   *  called (e.g. by deleting the displayed area selection object).   *  @param allReferences list of series/instance references registered for the presentation state.   *  @param instanceUID SOP instance UID of the current image   *  @param frame number of the current frame   *  @param numberOfFrames the number of frames of the current image      *  @param applicability applicability of the new displayed area selection   *  @param applicability the applicability of the image reference to be removed   *    (DVPSB_currentFrame or DVPSB_currentImage)   */  void removeImageReference(    DVPSReferencedSeries_PList& allReferences,    const char *instanceUID,    unsigned long frame,     unsigned long numberOfFrames,     DVPSObjectApplicability applicability);  /** removes all image references for this displayed area.   */  void clearImageReferences() { referencedImageList.clear(); }    /** checks if the list of image references for this displayed area is empty.   *  @return OFTrue if list of image references is empty, OFFalse otherwise.   */  OFBool imageReferencesEmpty() { if (referencedImageList.size()==0) return OFTrue; else return OFFalse; }  /** check if a VOI LUT is currently active   *  @return OFTrue if a VOI LUT is active, OFFalse if VOI Window is active.   */  OFBool haveLUT() { return useLUT; }  /** returns a description string for a currently active VOI transform.   *  If no description is available, NULL is returned.   *  @return a pointer to a string or NULL.   */  const char *getCurrentVOIDescription();  /** gets the width of the current VOI window.   *  May only be called if haveLUT() is OFFalse.   *  @param w the window width is returned in this parameter   *  @return EC_Normal upon success, an error code otherwise.   */    OFCondition getCurrentWindowWidth(double &w);    /** get the center of the current VOI window.   *  May only be called if haveLUT() is OFFalse.   *  @param c the window center is returned in this parameter   *  @return EC_Normal upon success, an error code otherwise.   */    OFCondition getCurrentWindowCenter(double &c);  /** returns a reference to the current VOI LUT descriptor.    *  May only be called if haveLUT() is OFTrue.   *  @return reference to the current VOI LUT descriptor   */    DcmUnsignedShort& getLUTDescriptor() { return voiLUTDescriptor; }  /** returns a reference to the current VOI LUT data.    *  May only be called if haveLUT() is OFTrue.   *  @return reference to the current VOI LUT data   */    DcmUnsignedShort& getLUTData() { return voiLUTData; }  /** sets a user defined VOI window center and width.   *  @param wCenter the window center   *  @param wWidth  the window width   *  @param description an optional description. Default: absent.   *  @return EC_Normal upon success, an error code otherwise.   */  OFCondition setVOIWindow(double wCenter, double wWidth, const char *description=NULL);  /** stores (copies) a VOI lookup table.   *  If the method returns an error code, an old LUT is left unchanged.   *  @param lutDescriptor the LUT Descriptor in DICOM format (VM=3)   *  @param lutData the LUT Data in DICOM format   *  @param lutExplanation the LUT Explanation in DICOM format, may be empty.   *  @return EC_Normal if successful, an error code otherwise.   */   OFCondition setVOILUT(     DcmUnsignedShort& lutDescriptor,    DcmUnsignedShort& lutData,    DcmLongString& lutExplanation);  /** 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  DVPSSoftcopyVOI& operator=(const DVPSSoftcopyVOI&);  /* since the VOI LUT sequence in the Softcopy VOI LUT module must   * not contain more than one item, we do not need to manage a list of   * VOI LUT SQ items.   */  /// ReferencedImageSequence, Type 1c  DVPSReferencedImage_PList referencedImageList;  /// If true, a VOI LUT is set, otherwise a VOI Window is set.  OFBool                   useLUT;     /// Module=VOI_LUT, VR=xs, VM=3, Type 1c   DcmUnsignedShort         voiLUTDescriptor;  /// Module=VOI_LUT, VR=LO, VM=1, Type 3   DcmLongString            voiLUTExplanation;  /// Module=VOI_LUT, VR=xs, VM=1-n, Type 1c   DcmUnsignedShort         voiLUTData;  /// Module=VOI_LUT, VR=DS, VM=1-n, Type 1c (unlike VOI LUT module!)   DcmDecimalString         windowCenter;  /// Module=VOI_LUT, VR=DS, VM=1-n, Type 1c   DcmDecimalString         windowWidth;  /// Module=VOI_LUT, VR=LO, VM=1-n, Type 3   DcmLongString            windowCenterWidthExplanation;  /** 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: dvpssv.h,v $ *  Revision 1.6  2005/12/08 16:04:05  meichel *  Changed include path schema for all DCMTK header files * *  Revision 1.5  2001/09/26 15:36:16  meichel *  Adapted dcmpstat to class OFCondition * *  Revision 1.4  2001/06/01 15:50:22  meichel *  Updated copyright header * *  Revision 1.3  2000/06/02 16:00:52  meichel *  Adapted all dcmpstat classes to use OFConsole for log and error output * *  Revision 1.2  2000/03/08 16:28:57  meichel *  Updated copyright header. * *  Revision 1.1  1999/07/22 16:39:12  meichel *  Adapted dcmpstat data structures and API to supplement 33 letter ballot text. * * */

⌨️ 快捷键说明

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