gdcmdict.h

来自「DTMK软件开发包,此为开源软件,是一款很好的医学图像开发资源.」· C头文件 代码 · 共 87 行

H
87
字号
/*=========================================================================
                                                                                
  Program:   gdcm
  Module:    $RCSfile: gdcmDict.h,v $
  Language:  C++
  Date:      $Date: 2006-02-18 12:36:38 $
  Version:   $Revision: 1.4 $
                                                                                
  Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
  l'Image). All rights reserved. See Doc/License.txt or
  http://www.creatis.insa-lyon.fr/Public/Gdcm/License.html for details.
                                                                                
     This software is distributed WITHOUT ANY WARRANTY; without even
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
     PURPOSE.  See the above copyright notices for more information.
                                                                                
=========================================================================*/

#ifndef GDCMDICT_H
#define GDCMDICT_H

#include "gdcmBase.h"
#include "gdcmDictEntry.h"

#include <iostream>
#include <fstream> // for ifstream
#include <list>
#include <map>

namespace gdcm 
{

//-----------------------------------------------------------------------------
typedef std::string DictKey;
typedef std::map<TagKey, DictEntry>  TagKeyHT;
//-----------------------------------------------------------------------------
/**
 * \brief    Dict acts a memory representation of a dicom dictionary i.e.
 *           it is a container for a collection of dictionary entries.
 *           The dictionary is loaded from in an ascii file.
 *           There should be a single public dictionary (THE dictionary of
 *           the actual DICOM v3) but as many shadow dictionaries as imagers 
 *           combined with all software versions...
 * \see DictSet
 */
class GDCM_EXPORT Dict : public Base
{
public:
   Dict();
   Dict(std::string const &filename);
   ~Dict();

   bool AddDict(std::string const &filename);
   bool RemoveDict(std::string const &filename);
// Print
   void Print(std::ostream &os = std::cout, std::string const &indent = "");

// Entries
   bool AddEntry(DictEntry const &newEntry);
   bool ReplaceEntry(DictEntry const &newEntry);
   bool RemoveEntry (TagKey const &key);
   bool RemoveEntry (uint16_t group, uint16_t elem);
   void ClearEntry();
   
// Tag
   DictEntry *GetEntry(uint16_t group, uint16_t elem);
   DictEntry *GetEntry(TagKey const &key);

   DictEntry *GetFirstEntry();
   DictEntry *GetNextEntry();

private:
   void DoTheLoadingJob(std::ifstream &ifs);

   /// ASCII file holding the Dictionnary
   std::string Filename;

   /// Access through TagKey
   TagKeyHT KeyHt;
   /// Iterator for the entries
   TagKeyHT::iterator ItKeyHt;
};
} // end namespace gdcm

//-----------------------------------------------------------------------------
#endif

⌨️ 快捷键说明

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