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

📄 dvpsri.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: DVPSReferencedImage * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:03:59 $ *  CVS/RCS Revision: $Revision: 1.9 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef __DVPSRI_H__#define __DVPSRI_H__#include "dcmtk/config/osconfig.h"    /* make sure OS specific configuration is included first */#include "dcmtk/dcmdata/dctk.h"/** an item of the referenced image sequence in a presentation state (internal use only). *  This class manages the data structures comprising one item *  of the Reference Image Sequence which is contained *  in the Referenced Series Sequence in a Presentation State object. */class DVPSReferencedImage{public:  /// default constructor  DVPSReferencedImage();    /// copy constructor  DVPSReferencedImage(const DVPSReferencedImage& copy);  /** clone method.   *  @return a pointer to a new DVPSReferencedImage object containing   *  a copy of this object.   */  DVPSReferencedImage *clone() { return new DVPSReferencedImage(*this); }  /// destructor  virtual ~DVPSReferencedImage();  /** reads an image reference from a DICOM dataset.   *  The DICOM elements of the referenced image 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 ReferencedImageSequence from which the data is to be read   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition read(DcmItem &dset);    /** writes the image reference 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 ReferencedImageSequence to which the data is written   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition write(DcmItem &dset);    /** check if the passed SOP Class UID is equal to the one stored in this object.   *  If sopclassuid is empty, the referencedSOPClassUID is assigned to it and the method returns   *  OFTrue. Otherwise the passed UID is compared with the referencedSOPClassUID.   *  OFTrue is returned if they are equal, OFFalse otherwise.   *  This method is used to check whether all image references in a presentation state   *  share the same SOP Class UID.   *  @param sopclassuid the SOP class UID to be validated   *  @return OFTrue if successful, OFFalse if unsuccessful.   */  OFBool validateSOPClassUID(OFString& sopclassuid);  /** set SOP Class UID of this image reference.   *  @param uid a pointer to the UID, which is copied into this object.   */  void setSOPClassUID(const char *uid);  /** set SOP Instance UID of this image reference.   *  @param uid a pointer to the UID, which is copied into this object.   */  void setSOPInstanceUID(const char *uid);      /** set the list of frame numbers of this image reference.   *  @param frames a list of frame numbers in DICOM IS format   *    (integer numbers separated by '\' characters)   */  void setFrameNumbers(const char *frames);  /** compare SOP Instance UID.   *  @param uid the UID to be compared   *  @return OFTrue if the referencedSOPInstanceUID of this object is   *    equal to uid, OFFalse otherwise.   */  OFBool isSOPInstanceUID(const char *uid);  /** gets the image reference managed by this object.   *  @param sopclassUID the SOP Class UID is returned in this string   *  @param instanceUID the SOP Instance UID is returned in this string   *  @param frames the list of frames is returned in this string   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition getImageReference(    OFString& sopclassUID,    OFString& instanceUID,     OFString& frames);  /** checks whether this image reference applies to the given frame number.   *  An image reference applies to a frame if the frame number is explicitly   *  listed in the referencedFrameNumber attribute or if the referencedFrameNumber   *  is empty.   *  @param frame frame number to be checked   *  @return OFTrue if the image reference applies to the given frame number, OFFalse otherwise.   */  OFBool appliesToFrame(unsigned long frame);  /** checks whether this image reference applies exactly to the given frame number.   *  This is the case if the referencedFrameNumber only contains the given frame number.   *  @param frame frame number to be checked   *  @return OFTrue if the image reference applies only to the given frame number, OFFalse otherwise.   */  OFBool appliesOnlyToFrame(unsigned long frame);  /** checks whether this image reference applies all frames   *  because the referencedFrameNumber is empty.   *  @return OFTrue if the image reference applies to all frames, OFFalse otherwise.   */  OFBool appliesToAllFrames();    /** update the reference such that the given frame is not referenced any more.   *  @param frame the frame reference   *  @param numberOfFrames the number of frames of the image reference   */  void removeFrameReference(unsigned long frame, unsigned long numberOfFrames);  /** 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:  /** undefined private assignment operator   */  DVPSReferencedImage& operator=(const DVPSReferencedImage& source);  /** flushes the frame cache.   */  void flushCache();  /** updated the frame cache.   */  void updateCache();    /// VR=UI, VM=1, Type 1c  DcmUniqueIdentifier      referencedSOPClassUID;  /// VR=UI, VM=1, Type 1c  DcmUniqueIdentifier      referencedSOPInstanceUID;  /// VR=IS, VM=1-n, Type 1c  DcmIntegerString         referencedFrameNumber;  /// if exists, contains binary representation of referencedFrameNumber  Sint32 *frameCache;  /// describes array size of frameCache  unsigned long frameCacheEntries;  /** 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: dvpsri.h,v $ *  Revision 1.9  2005/12/08 16:03:59  meichel *  Changed include path schema for all DCMTK header files * *  Revision 1.8  2001/09/26 15:36:14  meichel *  Adapted dcmpstat to class OFCondition * *  Revision 1.7  2001/06/01 15:50:20  meichel *  Updated copyright header * *  Revision 1.6  2000/06/02 16:00:50  meichel *  Adapted all dcmpstat classes to use OFConsole for log and error output * *  Revision 1.5  2000/03/08 16:28:55  meichel *  Updated copyright header. * *  Revision 1.4  1999/07/22 16:39:09  meichel *  Adapted dcmpstat data structures and API to supplement 33 letter ballot text. * *  Revision 1.3  1999/01/15 17:33:03  meichel *  added methods to DVPresentationState allowing to access the image *    references in the presentation state.  Also added methods allowing to *    get the width and height of the attached image. * *  Revision 1.2  1998/12/14 16:10:32  meichel *  Implemented Presentation State interface for graphic layers, *    text and graphic annotations, presentation LUTs. * *  Revision 1.1  1998/11/27 14:50:31  meichel *  Initial Release. * * */

⌨️ 快捷键说明

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