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

📄 dsrcontn.h

📁 转化为DIB位图再显示出来的dicom文件C++代码
💻 H
字号:
/* * *  Copyright (C) 2000-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: dcmsr * *  Author: Joerg Riesmeier * *  Purpose: *    classes: DSRContainerTreeNode * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:04:56 $ *  CVS/RCS Revision: $Revision: 1.11 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef DSRCONTN_H#define DSRCONTN_H#include "dcmtk/config/osconfig.h"   /* make sure OS specific configuration is included first */#include "dcmtk/dcmsr/dsrdoctr.h"/*---------------------* *  class declaration  * *---------------------*//** Class for content item CONTAINER */class DSRContainerTreeNode  : public DSRDocumentTreeNode{  public:    /** constructor     ** @param  relationshipType     type of relationship to the parent tree node.     *                               Should not be RT_invalid or RT_isRoot.     *  @param  continuityOfContent  Continuity of content flag (default: separate).     *                               Should be different from COC_invalid.     */    DSRContainerTreeNode(const E_RelationshipType relationshipType,                         const E_ContinuityOfContent continuityOfContent = COC_Separate);    /** destructor     */    virtual ~DSRContainerTreeNode();    /** clear all member variables.     *  Please note that the content item might become invalid afterwards.     */    virtual void clear();    /** check whether the content item is valid.     *  The content item is valid if the base class is valid, the continuity of content     *  flag is valid, and the concept name is valid or the content item is not the root item.     ** @return OFTrue if tree node is valid, OFFalse otherwise     */    virtual OFBool isValid() const;    /** check whether the content is short.     *  A container content item is defined to be never short (return always OFFalse).     ** @param  flags  flag used to customize the output (see DSRTypes::HF_xxx)     ** @return OFTrue if the content is short, OFFalse otherwise     */    virtual OFBool isShort(const size_t flags) const;    /** print content item.     *  A typical output looks like this: CONTAINER:(,,"Diagnosis")=SEPARATE for the root node     *  and contains CONTAINER:=CONTINUOUS for a "normal" content item.     ** @param  stream  output stream to which the content item should be printed     *  @param  flags   flag used to customize the output (see DSRTypes::PF_xxx)     ** @return status, EC_Normal if successful, an error code otherwise     */    virtual OFCondition print(ostream &stream,                              const size_t flags) const;    /** write content item in XML format     ** @param  stream     output stream to which the XML document is written     *  @param  flags      flag used to customize the output (see DSRTypes::XF_xxx)     *  @param  logStream  pointer to error/warning output stream (output disabled if NULL)     ** @return status, EC_Normal if successful, an error code otherwise     */    virtual OFCondition writeXML(ostream &stream,                                 const size_t flags,                                 OFConsole *logStream) const;    /** render content item in HTML format.     *  After rendering the current content item all child nodes (if any) are also rendered (see     *  renderHTMLChildNodes() for details).  This method overwrites the one specified in base class     *  DSRDocumentTree since the rendering of the child nodes depends on the value of the flag     *  'ContinuityOfContent'.     ** @param  docStream     output stream to which the main HTML document is written     *  @param  annexStream   output stream to which the HTML document annex is written     *  @param  nestingLevel  current nesting level.  Used to render section headings.     *  @param  annexNumber   reference to the variable where the current annex number is stored.     *                        Value is increased automatically by 1 after a new entry has been added.     *  @param  flags         flag used to customize the output (see DSRTypes::HF_xxx)     *  @param  logStream     pointer to error/warning output stream (output disabled if NULL)     ** @return status, EC_Normal if successful, an error code otherwise     */    virtual OFCondition renderHTML(ostream &docStream,                                   ostream &annexStream,                                   const size_t nestingLevel,                                   size_t &annexNumber,                                   const size_t flags,                                   OFConsole *logStream) const;    /** get continuity of content flag.     *  This flag specifies whether or not its contained content items (child nodes) are     *  logically linked in a continuous textual flow, or are sparate items.     ** @return continuity of content flag if successful, COC_invalid otherwise     */    inline E_ContinuityOfContent getContinuityOfContent() const    {        return ContinuityOfContent;    }    /** set continuity of content flag.     *  This flag specifies whether or not its contained content items (child nodes) are     *  logically linked in a continuous textual flow, or are sparate items.     ** @param  continuityOfContent  value to be set (should be different from COC_onvalid)     ** @return status, EC_Normal if successful, an error code otherwise     */    OFCondition setContinuityOfContent(const E_ContinuityOfContent continuityOfContent);  protected:    /** read content item (value) from dataset     ** @param  dataset    DICOM dataset from which the content item should be read     *  @param  logStream  pointer to error/warning output stream (output disabled if NULL)     ** @return status, EC_Normal if successful, an error code otherwise     */    virtual OFCondition readContentItem(DcmItem &dataset,                                        OFConsole *logStream);    /** write content item (value) to dataset     ** @param  dataset    DICOM dataset to which the content item should be written     *  @param  logStream  pointer to error/warning output stream (output disabled if NULL)     ** @return status, EC_Normal if successful, an error code otherwise     */    virtual OFCondition writeContentItem(DcmItem &dataset,                                         OFConsole *logStream) const;    /** read content item specific XML data     ** @param  doc     document containing the XML file content     *  @param  cursor  cursor pointing to the starting node     ** @return status, EC_Normal if successful, an error code otherwise     */    virtual OFCondition readXMLContentItem(const DSRXMLDocument &doc,                                           DSRXMLCursor cursor);    /** render content item (value) in HTML format     ** @param  docStream     output stream to which the main HTML document is written     *  @param  annexStream   output stream to which the HTML document annex is written     *  @param  nestingLevel  current nesting level.  Used to render section headings.     *  @param  annexNumber   reference to the variable where the current annex number is stored.     *                        Value is increased automatically by 1 after a new entry has been added.     *  @param  flags         flag used to customize the output (see DSRTypes::HF_xxx)     *  @param  logStream     pointer to error/warning output stream (output disabled if NULL)     ** @return status, EC_Normal if successful, an error code otherwise     */    virtual OFCondition renderHTMLContentItem(ostream &docStream,                                              ostream &annexStream,                                              const size_t nestingLevel,                                              size_t &annexNumber,                                              const size_t flags,                                              OFConsole *logStream) const;  private:    /// continuity of content flag (associated DICOM VR=CS, mandatory)    E_ContinuityOfContent ContinuityOfContent; // --- declaration of default/copy constructor and assignment operator    DSRContainerTreeNode();    DSRContainerTreeNode(const DSRContainerTreeNode &);    DSRContainerTreeNode &operator=(const DSRContainerTreeNode &);};#endif/* *  CVS/RCS Log: *  $Log: dsrcontn.h,v $ *  Revision 1.11  2005/12/08 16:04:56  meichel *  Changed include path schema for all DCMTK header files * *  Revision 1.10  2003/09/15 14:18:54  joergr *  Introduced new class to facilitate checking of SR IOD relationship content *  constraints. Replaced old implementation distributed over numerous classes. * *  Revision 1.9  2003/08/07 12:23:17  joergr *  Added readXML functionality. *  Updated documentation to get rid of doxygen warnings. * *  Revision 1.8  2001/11/09 16:10:47  joergr *  Added preliminary support for Mammography CAD SR. * *  Revision 1.7  2001/09/26 13:04:05  meichel *  Adapted dcmsr to class OFCondition * *  Revision 1.6  2001/06/01 15:51:00  meichel *  Updated copyright header * *  Revision 1.5  2000/11/07 18:14:28  joergr *  Enhanced support for by-reference relationships. * *  Revision 1.4  2000/11/01 16:14:26  joergr *  Added support for conversion to XML. * *  Revision 1.3  2000/10/23 15:09:27  joergr *  Added/updated doc++ comments. * *  Revision 1.2  2000/10/18 17:01:17  joergr *  Made some functions inline. * *  Revision 1.1  2000/10/13 07:49:24  joergr *  Added new module 'dcmsr' providing access to DICOM structured reporting *  documents (supplement 23).  Doc++ documentation not yet completed. * * */

⌨️ 快捷键说明

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