X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDicomDirMeta.cxx;h=0c98a59d551d94e1f110663e6b69c6d27985749c;hb=f2dd0107ba49eda3386b34715cdc0c046d12397f;hp=3d62dc360e98e0b1efed5905670dbf791130e9fd;hpb=55d77e0913ff360d639af1841c70d14dc8687584;p=gdcm.git diff --git a/src/gdcmDicomDirMeta.cxx b/src/gdcmDicomDirMeta.cxx index 3d62dc36..0c98a59d 100644 --- a/src/gdcmDicomDirMeta.cxx +++ b/src/gdcmDicomDirMeta.cxx @@ -1,55 +1,134 @@ -// gdcmDicomDirMeta.h -//----------------------------------------------------------------------------- +/*========================================================================= + + Program: gdcm + Module: $RCSfile: gdcmDicomDirMeta.cxx,v $ + Language: C++ + Date: $Date: 2007/08/29 15:30:48 $ + Version: $Revision: 1.39 $ + + 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. + +=========================================================================*/ + #include "gdcmDicomDirMeta.h" +#include "gdcmDocument.h" +#include "gdcmDocEntry.h" +#include "gdcmGlobal.h" +#include "gdcmUtil.h" +#include "gdcmDataEntry.h" +namespace GDCM_NAME_SPACE +{ //----------------------------------------------------------------------------- // Constructor / Destructor - /** - * \ingroup gdcmMeta * \brief Constructor - * @param begin iterator (inside the gdcmParser chained list) - * on the first Header Entry (i.e Dicom Element) - * related to the "META" part - * @param end iterator (inside the gdcmParser chained list) - * on the last Header Entry (i.e Dicom Element) - * related to the 'META' part - * @param ptagHT pointer to the HTable (gdcmObject needs it - * to build the gdcmHeaderEntries) - * @param plistEntries pointer to the chained List (gdcmObject needs it - * to build the gdcmHeaderEntries) */ -gdcmDicomDirMeta::gdcmDicomDirMeta(ListTag::iterator begin, - ListTag::iterator end, - TagHeaderEntryHT *ptagHT, - ListTag *plistEntries): - gdcmObject(begin,end,ptagHT,plistEntries) +DicomDirMeta::DicomDirMeta(bool empty): + DicomDirObject() { + if ( !empty ) + { + ListDicomDirStudyElem const &elemList = + Global::GetDicomDirElements()->GetDicomDirMetaElements(); + FillObject(elemList); + } } /** - * \ingroup gdcmDicomDirMeta * \brief Canonical destructor. */ -gdcmDicomDirMeta::~gdcmDicomDirMeta() +DicomDirMeta::~DicomDirMeta() { } //----------------------------------------------------------------------------- -// Print +// Public /** - * \ingroup gdcmDicomDirMeta - * \brief Prints the Object + * \brief Writes the Meta Elements + * @param fp ofstream to write to + * @param filetype type of the file (ImplicitVR, ExplicitVR, JPEG, JPEG2000 ...) * @return */ -void gdcmDicomDirMeta::Print(std::ostream &os) +void DicomDirMeta::WriteContent(std::ofstream *fp, FileType filetype, + bool dummy, bool dummy2) { - os<<"META"<CopyBinArea(fmiv, 2); + + // 'Media Storage SOP Instance UID' + DataEntry *e00002_0003 = GetDataEntry(0x0002,0x0003); + e00002_0003->SetString(Util::CreateUniqueUID()); + + // 'Implementation Class UID' + DataEntry *e00002_0012 = GetDataEntry(0x0002,0x0012); + e00002_0012->SetString(Util::CreateUniqueUID()); + + // Entry : 0002|0000 = group length -> recalculated + DataEntry *e0000 = GetDataEntry(0x0002,0x0000); + std::ostringstream sLen; + sLen << ComputeGroup0002Length( ); + e0000->SetString(sLen.str()); + + for (ListDocEntry::iterator i = DocEntries.begin(); + i!= DocEntries.end(); + ++i) + { + // true : we are in MetaElements + (*i)->WriteContent(fp, filetype, true, false); + } } -//----------------------------------------------------------------------------- -// Public +/** + * \brief Re-computes the length of the Dicom group 0002 (in the DicomDirMeta) + */ +int DicomDirMeta::ComputeGroup0002Length( ) +{ + uint16_t gr; + VRKey vr; + + int groupLength = 0; + bool found0002 = false; + + // for each Tag in the DicomDirMeta + DocEntry *entry = GetFirstEntry(); + while( entry ) + { + gr = entry->GetGroup(); + + if ( gr == 0x0002 ) + { + found0002 = true; + + if ( entry->GetElement() != 0x0000 ) + { + vr = entry->GetVR(); + + if ( vr == "OB" ) + { + groupLength += 4; + } + groupLength += 2 + 2 + 4 + entry->GetLength(); + } + } + else if (found0002 ) + break; + + entry = GetNextEntry(); + } + return groupLength; +} //----------------------------------------------------------------------------- // Protected @@ -58,3 +137,25 @@ void gdcmDicomDirMeta::Print(std::ostream &os) // Private //----------------------------------------------------------------------------- +// Print +/** + * \brief Prints the Meta Elements + * @param os ostream to write to + * @param indent Indentation string to be prepended during printing + */ +void DicomDirMeta::Print(std::ostream &os, std::string const & ) +{ + os << "META" << std::endl; + // warning : META doesn't behave exactly like a Objet + for (ListDocEntry::iterator i = DocEntries.begin(); + i != DocEntries.end(); + ++i) + { + (*i)->SetPrintLevel(PrintLevel); + (*i)->Print(); + os << std::endl; + } +} + +//----------------------------------------------------------------------------- +} // end namespace gdcm