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

📄 dvpsga.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: DVPSGraphicAnnotation * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:03:43 $ *  CVS/RCS Revision: $Revision: 1.8 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef __DVPSGA_H__#define __DVPSGA_H__#include "dcmtk/config/osconfig.h"    /* make sure OS specific configuration is included first */#include "dcmtk/dcmdata/dctk.h"#include "dcmtk/dcmpstat/dvpstxl.h"     /* for DVPSTextObject_PList */#include "dcmtk/dcmpstat/dvpsgrl.h"     /* for DVPSGraphicObject_PList */#include "dcmtk/dcmpstat/dvpsril.h"     /* for DVPSReferencedImage_PList */#include "dcmtk/dcmpstat/dvpstyp.h"     /* for enum types *//** an item of the graphic annotation sequence in a presentation state (internal use only). *  This class manages the data structures comprising one item *  of the Graphic Annotation Sequence in a Presentation State object. */class DVPSGraphicAnnotation{public:  /// default constructor  DVPSGraphicAnnotation();    /// copy constructor  DVPSGraphicAnnotation(const DVPSGraphicAnnotation& copy);  /** clone method.   *  @return a pointer to a new DVPSGraphicAnnotation object containing   *  a deep copy of this object.   */  DVPSGraphicAnnotation *clone() { return new DVPSGraphicAnnotation(*this); }  /// destructor  virtual ~DVPSGraphicAnnotation();  /** reads a graphic annotation from a DICOM dataset.   *  The DICOM elements of the Graphic Annotation 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 GraphicAnnotationSequence from which the data is to be read   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition read(DcmItem &dset);  /** writes the graphic annotation managed by this object to a DICOM dataset.   *  Copies of the DICOM element managed by this object are inserted into   *  the DICOM dataset.   *  @param dset the the item of the GraphicAnnotationSequence to which the data is written   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition write(DcmItem &dset);  /** get annotation layer name.   *  @return a pointer to the annotation layer name   */  const char *getAnnotationLayer();  /** set annotation layer name of this annotation.   *  @param aLayer a pointer to the annotation layer name, which is copied into this object.   */  void setAnnotationLayer(const char *aLayer);  /** 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 DVPSX_currentImage)   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition addImageReference(    const char *sopclassUID,    const char *instanceUID,     unsigned long frame,    DVPSObjectApplicability applicability);      /** checks if this annotation layer is empty.   *  An annotation layer is empty when it contains no text object and no graphic object.   *  @return OFTrue if empty.   */  OFBool isEmpty();  /** checks if this annotation layer is applicable to the given image and frame.   *  @param instanceUID SOP instance UID of the current image   *  @param frame number of the current frame   *  @param applicability the required (minimum) applicability of the reference. Default:   *    annotation layer applies to the current frame of the current image.   *  @return OFTrue if applicable.   */  OFBool isApplicable(        const char *instanceUID,     unsigned long frame,    DVPSObjectApplicability applicability=DVPSB_currentFrame);      /** returns the number of text objects in this annotation.   *  @return number of text objects   */  size_t getNumberOfTextObjects();    /** returns the number of graphic objects in this annotation.   *  @return number of graphic objects   */  size_t getNumberOfGraphicObjects();    /** returns a pointer to the text object with the given   *  index or NULL if it does not exist.   *  @param idx index, must be < getNumberOfTextObjects()   *  @return pointer to text object or NULL   */  DVPSTextObject *getTextObject(size_t idx);  /** returns a pointer to the graphic object with the given   *  index or NULL if it does not exist.   *  @param idx index, must be < getNumberOfGraphicObjects()   *  @return pointer to graphic object or NULL   */  DVPSGraphicObject *getGraphicObject(size_t idx);  /** adds the given text object to   *  the list of text objects managed by this object.   *  @param text text object to be inserted.   */  void addTextObject(DVPSTextObject *text);  /** adds the given graphic object to   *  the list of graphic objects managed by this object.   *  @param text graphic object to be inserted.   */  void addGraphicObject(DVPSGraphicObject *graphic);    /** returns a pointer to the text object with the given   *  index (or NULL if it does not exist) and removes it from the list.   *  @param idx index, must be < getNumberOfTextObjects()   *  @return pointer to text object or NULL   */  DVPSTextObject *removeTextObject(size_t idx);  /** returns a pointer to the graphic object with the given   *  index (or NULL if it does not exist) and removes it from the list.   *  @param idx index, must be < getNumberOfGraphicObjects()   *  @return pointer to graphic object or NULL   */  DVPSGraphicObject *removeGraphicObject(size_t idx);  /** 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  DVPSGraphicAnnotation& operator=(const DVPSGraphicAnnotation&);  /// ReferencedImageSequence, Type 1c  DVPSReferencedImage_PList referencedImageList;  /// VR=CS, VM=1, Type 1   DcmCodeString             graphicAnnotationLayer;  /// TextObjectSequence, Type 1c   DVPSTextObject_PList      textObjectList;  /// GraphicObjectSequence, Type 1c     DVPSGraphicObject_PList   graphicObjectList;  /** 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: dvpsga.h,v $ *  Revision 1.8  2005/12/08 16:03:43  meichel *  Changed include path schema for all DCMTK header files * *  Revision 1.7  2001/09/26 15:36:10  meichel *  Adapted dcmpstat to class OFCondition * *  Revision 1.6  2001/06/01 15:50:15  meichel *  Updated copyright header * *  Revision 1.5  2000/06/02 16:00:45  meichel *  Adapted all dcmpstat classes to use OFConsole for log and error output * *  Revision 1.4  2000/03/08 16:28:51  meichel *  Updated copyright header. * *  Revision 1.3  1999/07/22 16:39:06  meichel *  Adapted dcmpstat data structures and API to supplement 33 letter ballot text. * *  Revision 1.2  1998/12/14 16:10:27  meichel *  Implemented Presentation State interface for graphic layers, *    text and graphic annotations, presentation LUTs. * *  Revision 1.1  1998/11/27 14:50:26  meichel *  Initial Release. * * */

⌨️ 快捷键说明

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