X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDicomDirImage.cxx;h=e13bc8911ce4db4b6f1e7d2b627e59376d0b175c;hb=df832cf7f90b4ca5aca2f628c1756fb276779fac;hp=0ddbfc463409c2279101918589e7abb4b9527875;hpb=a891240601e102b6b07ce593d9b9b28948149e72;p=gdcm.git diff --git a/src/gdcmDicomDirImage.cxx b/src/gdcmDicomDirImage.cxx index 0ddbfc46..e13bc891 100644 --- a/src/gdcmDicomDirImage.cxx +++ b/src/gdcmDicomDirImage.cxx @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmDicomDirImage.cxx,v $ Language: C++ - Date: $Date: 2005/01/18 14:28:32 $ - Version: $Revision: 1.18 $ + Date: $Date: 2007/05/23 14:18:08 $ + Version: $Revision: 1.25 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -17,19 +17,28 @@ =========================================================================*/ #include "gdcmDicomDirImage.h" -#include "gdcmValEntry.h" +#include "gdcmGlobal.h" +#include "gdcmDataEntry.h" -namespace gdcm +namespace GDCM_NAME_SPACE { //----------------------------------------------------------------------------- // Constructor / Destructor /** * \brief Constructor + * \note End user must use : DicomDirSerie::NewImage() */ -DicomDirImage::DicomDirImage(): +DicomDirImage::DicomDirImage(bool empty): DicomDirObject() { + if ( !empty ) + { + ListDicomDirImageElem const &elemList = + Global::GetDicomDirElements()->GetDicomDirImageElements(); + FillObject(elemList); + } } + /** * \brief Canonical destructor. */ @@ -37,12 +46,21 @@ DicomDirImage::~DicomDirImage() { } +//----------------------------------------------------------------------------- +// Public + +//----------------------------------------------------------------------------- +// Protected + +//----------------------------------------------------------------------------- +// Private + //----------------------------------------------------------------------------- // Print /** * \brief Prints the Object * @param os ostream to write to - * @param indent indent + * @param indent Indentation string to be prepended during printing * @return */ void DicomDirImage::Print(std::ostream &os, std::string const & ) @@ -52,9 +70,10 @@ void DicomDirImage::Print(std::ostream &os, std::string const & ) i!= DocEntries.end(); ++i) { - if( (*i)->GetGroup() == 0x0004 && (*i)->GetElement() == 0x1500 ) + if ( (*i)->GetGroup() == 0x0004 && (*i)->GetElement() == 0x1500 ) { - os << ((ValEntry *)(*i))->GetValue(); //FIXME + if( dynamic_cast(*i) ) + os << (dynamic_cast(*i))->GetString(); } } os << std::endl; @@ -62,15 +81,6 @@ void DicomDirImage::Print(std::ostream &os, std::string const & ) DicomDirObject::Print(os); } -//----------------------------------------------------------------------------- -// Public - -//----------------------------------------------------------------------------- -// Protected - -//----------------------------------------------------------------------------- -// Private - //----------------------------------------------------------------------------- } // end namespace gdcm