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

📄 dcdicdir.h

📁 转化为DIB位图再显示出来的dicom文件C++代码
💻 H
字号:
/* * *  Copyright (C) 1994-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:  dcmdata * *  Author:  Gerd Ehlers, Andreas Barth * *  Purpose: Interface of class DcmDicomDir * *  Last Update:      $Author: meichel $ *  Update Date:      $Date: 2005/12/08 16:28:07 $ *  Source File:      $Source: /share/dicom/cvs-depot/dcmtk/dcmdata/include/dcmtk/dcmdata/dcdicdir.h,v $ *  CVS/RCS Revision: $Revision: 1.19 $ *  Status:           $State: Exp $ * *  CVS/RCS Log at end of file * */#ifndef DCDICDIR_H#define DCDICDIR_H#include "dcmtk/config/osconfig.h"    /* make sure OS specific configuration is included first */#include "dcmtk/ofstd/ofconsol.h"#include "dcmtk/dcmdata/dctypes.h"#include "dcmtk/dcmdata/dcitem.h"#include "dcmtk/dcmdata/dcfilefo.h"#include "dcmtk/dcmdata/dcsequen.h"#include "dcmtk/dcmdata/dcdirrec.h"#include "dcmtk/dcmdata/dcvrulup.h"#define DEFAULT_DICOMDIR_NAME  "DICOMDIR"#define TEMPNAME_TEMPLATE      "DDXXXXXX"#define DICOMDIR_BACKUP_SUFFIX ".$$$"#define DICOMDIR_DEFAULT_TRANSFERSYNTAX  EXS_LittleEndianExplicittypedef struct{    DcmItem *item;    Uint32  fileOffset;} ItemOffset;class DcmDicomDir{  private: // --- declarations to avoid compiler warnings    DcmDicomDir &operator=(const DcmDicomDir &);    DcmDicomDir( const DcmDicomDir &newDir );  protected:    OFCondition errorFlag;    char * dicomDirFileName;    OFBool modified;              // wird wo gebraucht ?    OFBool mustCreateNewDir;    DcmFileFormat * DirFile;    DcmDirectoryRecord * RootRec;    DcmSequenceOfItems * MRDRSeq;    // Manipulation der internen Datenelemente:    OFCondition createNewElements(const char* fileSetID);  // in    DcmDataset& getDataset(void);    // Seiteneffekt-freie Methoden zur Manipulation und Konversion:    DcmSequenceOfItems&    getDirRecSeq(      DcmDataset &dset );   // inout    DcmUnsignedLongOffset* lookForOffsetElem( DcmObject *obj,       // in                                              const DcmTagKey &offsetTag );// in    DcmDirectoryRecord*    recurseMatchFile(  DcmDirectoryRecord* startRec,// in                                              char *filename );            // in    DcmDirectoryRecord*    searchMatchFile(   DcmSequenceOfItems& recSeq,  // in                                              char *filename );            // in    OFCondition resolveGivenOffsets( DcmObject *startPoint,         // inout                                     ItemOffset *itOffsets,         // in                                     const unsigned long numOffsets,  // in                                     const DcmTagKey &offsetTag );  // in    OFCondition resolveAllOffsets(   DcmDataset &dset );            // inout    OFCondition linkMRDRtoRecord(    DcmDirectoryRecord *dRec );    // inout    OFCondition moveRecordToTree(    DcmDirectoryRecord *startRec,  // in                                     DcmSequenceOfItems &fromDirSQ, // inout                                     DcmDirectoryRecord *toRecord );// inout    OFCondition moveMRDRbetweenSQs(  DcmSequenceOfItems &fromSQ,    // in                                     DcmSequenceOfItems &toDirSQ ); // inout    Uint32     lengthUntilSQ(       DcmDataset &dset,              // in                                     E_TransferSyntax oxfer,        // in                                     E_EncodingType enctype );      // in    Uint32     lengthOfRecord(      DcmItem *item,                 // in                                     E_TransferSyntax oxfer,        // in                                     E_EncodingType enctype );      // in    OFCondition convertGivenPointer( DcmObject *startPoint,         // inout                                     ItemOffset *itOffsets,         // in                                     const unsigned long numOffsets,  // in                                     const DcmTagKey &offsetTag );  // in    OFCondition convertAllPointer(   DcmDataset &dset,              // inout                                     Uint32 beginOfFileSet,        // in                                     E_TransferSyntax oxfer,        // in                                     E_EncodingType enctype );      // in    OFCondition copyRecordPtrToSQ(   DcmDirectoryRecord *record,    // in                                     DcmSequenceOfItems &toDirSQ,   // inout                                     DcmDirectoryRecord **firstRec, // out                                     DcmDirectoryRecord **lastRec );// out    OFCondition insertMediaSOPUID(   DcmMetaInfo &metaInfo );       // inout    OFCondition countMRDRRefs(       DcmDirectoryRecord *startRec,  // in                                     ItemOffset *refCounter,        // inout                                     const unsigned long numCounters );   // in    OFCondition checkMRDRRefCounter( DcmDirectoryRecord *startRec,  // in                                     ItemOffset *refCounter,        // inout                                     const unsigned long numCounters );    // in    // komplette Reorganisation der verwalteten Directory Records (Seiteneffekt)    OFCondition convertLinearToTree();    OFCondition convertTreeToLinear( Uint32 beginOfFileSet,         // in                                     E_TransferSyntax oxfer,        // in                                     E_EncodingType enctype,        // in                                     E_GrpLenEncoding glenc,        // in                                     DcmSequenceOfItems &unresRecs);// inoutpublic:    DcmDicomDir();    DcmDicomDir( const char *fileName,                 const char *fileSetID = NULL );  // only used for new DICOMDIR    virtual ~DcmDicomDir();    virtual void print(ostream &out,                       const size_t flags = 0,                       const int level = 0,                       const char *pixelFileName = NULL,                       size_t *pixelCounter = NULL);    virtual OFCondition         error();    virtual DcmFileFormat&      getDirFileFormat();    virtual const char*         getDirFileName();    virtual DcmDirectoryRecord& getRootRecord();    virtual DcmSequenceOfItems& getMRDRSequence();    virtual DcmDirectoryRecord* matchFilename(     char *filename );    virtual DcmDirectoryRecord* matchOrCreateMRDR( char *filename );    virtual OFCondition         write(const E_TransferSyntax oxfer                                            = DICOMDIR_DEFAULT_TRANSFERSYNTAX,                                      const E_EncodingType enctype                                            = EET_UndefinedLength,                                      const E_GrpLenEncoding glenc                                            = EGL_withoutGL );// PENDING: DICOM-konform, aber unvollstaendig    virtual OFCondition         verify( OFBool autocorrect = OFFalse );};#endif // DCDICDIR_H/*** CVS/RCS Log:** $Log: dcdicdir.h,v $** Revision 1.19  2005/12/08 16:28:07  meichel** Changed include path schema for all DCMTK header files**** Revision 1.18  2005/11/07 16:59:24  meichel** Cleaned up some copy constructors in the DcmObject hierarchy.**** Revision 1.17  2003/08/14 09:00:56  meichel** Adapted type casts to new-style typecast operators defined in ofcast.h**** Revision 1.16  2002/12/06 12:49:09  joergr** Enhanced "print()" function by re-working the implementation and replacing** the boolean "showFullData" parameter by a more general integer flag.** Added doc++ documentation.** Made source code formatting more consistent with other modules/files.**** Revision 1.15  2001/09/25 17:19:25  meichel** Adapted dcmdata to class OFCondition**** Revision 1.14  2001/06/01 15:48:36  meichel** Updated copyright header**** Revision 1.13  2000/04/14 15:31:31  meichel** Removed default value from output stream passed to print() method.**   Required for use in multi-thread environments.**** Revision 1.12  2000/03/08 16:26:12  meichel** Updated copyright header.**** Revision 1.11  2000/03/03 14:05:23  meichel** Implemented library support for redirecting error messages into memory**   instead of printing them to stdout/stderr for GUI applications.**** Revision 1.10  2000/02/10 10:50:50  joergr** Added new feature to dcmdump (enhanced print method of dcmdata): write** pixel data/item value fields to raw files.**** Revision 1.9  1999/03/31 09:24:34  meichel** Updated copyright header in module dcmdata**** Revision 1.8  1998/07/15 15:48:44  joergr** Removed several compiler warnings reported by gcc 2.8.1 with** additional options, e.g. missing copy constructors and assignment** operators, initialization of member variables in the body of a** constructor instead of the member initialization list, hiding of** methods by use of identical names, uninitialized member variables,** missing const declaration of char pointers. Replaced tabs by spaces.**** Revision 1.7  1997/09/11 15:02:16  hewett** Changed DcmDicomDir constructor to take const char* arguments.**** Revision 1.6  1997/07/21 08:25:06  andreas** - Replace all boolean types (BOOLEAN, CTNBOOLEAN, DICOM_BOOL, BOOL)**   with one unique boolean type OFBool.**** Revision 1.5  1997/05/16 08:31:19  andreas** - Revised handling of GroupLength elements and support of**   DataSetTrailingPadding elements. The enumeratio E_GrpLenEncoding**   got additional enumeration values (for a description see dctypes.h).**   addGroupLength and removeGroupLength methods are replaced by**   computeGroupLengthAndPadding. To support Padding, the parameters of**   element and sequence write functions changed.**** Revision 1.4  1997/04/24 12:08:28  hewett** Fixed DICOMDIR generation bug affecting inclusion of Group Length** attributes (file offsets were not being computed correctly).**** Revision 1.3  1996/08/05 08:45:18  andreas** new print routine with additional parameters:**         - print into files**         - fix output length for elements** corrected error in search routine with parameter ESM_fromStackTop**** Revision 1.2  1996/01/05 13:22:54  andreas** - changed to support new streaming facilities** - more cleanups** - merged read / write methods for block and file transfer***/

⌨️ 快捷键说明

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