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

📄 dvpsfs.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: DVPSFilmSession * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:03:42 $ *  CVS/RCS Revision: $Revision: 1.6 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef __DVPSFS_H__#define __DVPSFS_H__#include "dcmtk/config/osconfig.h"    /* make sure OS specific configuration is included first */#include "dcmtk/dcmdata/dctk.h"#include "dcmtk/dcmpstat/dvpstyp.h"#include "dcmtk/dcmnet/dimse.h"class DVConfiguration;class DVPSPresentationLUT_PList;class DVPSStoredPrint_PList;class DVPSStoredPrint;/** a basic film session object managed by a Print SCP. */class DVPSFilmSession{public:  /** constructor   *  @param illumin default Illumination setting   *  @param reflection default Reflected Ambient Light setting   */  DVPSFilmSession(Uint16 illumin, Uint16 reflection);    /// copy constructor  DVPSFilmSession(const DVPSFilmSession& copy);  /** clone method.   *  @return a pointer to a new DVPSFilmSession object containing   *  a copy of this object.   */  DVPSFilmSession *clone() { return new DVPSFilmSession(*this); }  /// destructor  virtual ~DVPSFilmSession();  /** performs a Print SCP Basic Film Session N-CREATE operation on a newly    *  created instance of this class. The results of the operation are    *  stored in the objects passed as rsp and rspDataset.   *  @param cfg config file facility   *  @param cfgname symbolic printer name in config file   *  @param rqDataset N-CREATE request dataset, may be NULL   *  @param rsp N-CREATE response message   *  @param rspDataset N-CREATE response dataset passed back in this parameter   *  @param peerae application entity title of the print SCU we're    *    communicating with. Used to create default values for ownerID   *    and filmSessionLabel.   *  @param presentationLUTnegotiated    *    OFTrue if support for the Presentation LUT SOP class   *    has been negotiated at association negotiation and is supported on   *    Basic Film Session level   *  @param globalPresentationLUTList   *    list of presentation LUTs managed by the Print SCP   *  @return OFTrue if N-CREATE was successful, OFFalse otherwise.   */  OFBool printSCPCreate(    DVConfiguration& cfg,     const char *cfgname,     DcmDataset *rqDataset,     T_DIMSE_Message& rsp,     DcmDataset *& rspDataset,     const char *peerae,    OFBool presentationLUTnegotiated,    DVPSPresentationLUT_PList& globalPresentationLUTList);  /** performs a Print SCP Basic Film Session N-SET operation on an instance    *  of this class. The results of the N-SET operation are stored in the    *  objects passed as rsp and rspDataset.   *  @param cfg config file facility   *  @param cfgname symbolic printer name in config file   *  @param rqDataset N-SET request dataset   *  @param rsp N-SET response message   *  @param rspDataset N-SET response dataset passed back in this parameter   *  @param presentationLUTnegotiated    *    OFTrue if support for the Presentation LUT SOP class   *    has been negotiated at association negotiation and is supported on   *    Basic Film Session level   *  @param globalPresentationLUTList   *    list of presentation LUTs managed by the Print SCP   *  @param basicFilmBoxList list of basic film boxes. Presentation LUT   *    settings are copied to all film boxes.   *  @return OFTrue if N-SET was successful, OFFalse otherwise.   */      OFBool printSCPSet(    DVConfiguration& cfg,     const char *cfgname,     DcmDataset *rqDataset,     T_DIMSE_Message& rsp,     DcmDataset *& rspDataset,    OFBool presentationLUTnegotiated,    DVPSPresentationLUT_PList& globalPresentationLUTList,    DVPSStoredPrint_PList& basicFilmBoxList);  /** compares the SOP instance UID with the given UID string.   *  @return OFTrue if UIDs are equal, OFFalse otherwise.   */  OFBool isInstance(const char *uid);    /** returns the SOP instance UID of the basic film session.   *  @return SOP instance UID   */  const char *getUID() { return sopInstanceUID.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);  /** copies the film box Presentation LUT settings into the   *  stored print object passed by reference.   *  @param sp stored print object   */  void copyPresentationLUTSettings(DVPSStoredPrint& sp);  private:  /// private undefined assignment operator  DVPSFilmSession& operator=(const DVPSFilmSession&);  /** writes a Referenced Presentation LUT SQ, Illumination and   *  reflected ambient light to the given dataset.   *  Helper function used when creating Basic Film Session or   *  Basic Film Box.   *  @param dset the dataset to which the data is written   *  @return EC_Normal if successful, an error code otherwise.   */  OFCondition addPresentationLUTReference(DcmItem& dset);  /// SOP instance UID of basic film session object  OFString                 sopInstanceUID;  /// VR=IS, VM=1  DcmIntegerString         numberOfCopies;  /// VR=CS, VM=1  DcmCodeString            printPriority;  /// VR=CS, VM=1  DcmCodeString            mediumType;  /// VR=CS, VM=1  DcmCodeString            filmDestination;  /// VR=LO, VM=1  DcmLongString            filmSessionLabel;  /// VR=SH, VM=1  DcmShortString           ownerID;    /// VR=US, VM=1, Type 2c required if presentation SOP class present  DcmUnsignedShort         illumination;  /// VR=US, VM=1, Type 2c required if presentation SOP class present  DcmUnsignedShort         reflectedAmbientLight;  /// the ReferencedPresentationLUTSequence is only created/read on the fly  DcmUniqueIdentifier      referencedPresentationLUTInstanceUID;  /** The Print SCP can be configured to enforce a rule requiring that the    *  number of entries in a Presentation LUT matches the bit depth of the    *  image pixel data. This member variable describes the type of the    *  current presentation LUT (if any).   */  DVPSPrintPresentationLUTAlignment referencedPresentationLUTAlignment;  /** 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: dvpsfs.h,v $ *  Revision 1.6  2005/12/08 16:03:42  meichel *  Changed include path schema for all DCMTK header files * *  Revision 1.5  2001/09/26 15:36:10  meichel *  Adapted dcmpstat to class OFCondition * *  Revision 1.4  2001/06/01 15:50:15  meichel *  Updated copyright header * *  Revision 1.3  2000/06/08 10:44:28  meichel *  Implemented Referenced Presentation LUT Sequence on Basic Film Session level. *    Empty film boxes (pages) are not written to file anymore. * *  Revision 1.2  2000/06/02 16:00:45  meichel *  Adapted all dcmpstat classes to use OFConsole for log and error output * *  Revision 1.1  2000/05/31 12:56:35  meichel *  Added initial Print SCP support * * */

⌨️ 快捷键说明

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