X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src2%2FcreaImageIODicomImageReader.cpp;h=30c420914cc2a7ca00c96aa8ce979fd666be0ddd;hb=b0843014c5482f70050fab8036c6780172e3b6c9;hp=95619e5f11ccf6f5a8c3b3fa0de968c2f829effe;hpb=805ec93a6b36ad6acf63458414c545a737322354;p=creaImageIO.git diff --git a/src2/creaImageIODicomImageReader.cpp b/src2/creaImageIODicomImageReader.cpp index 95619e5..30c4209 100644 --- a/src2/creaImageIODicomImageReader.cpp +++ b/src2/creaImageIODicomImageReader.cpp @@ -1,10 +1,11 @@ #include -#include + #include #include #include "boost/filesystem/path.hpp" #include +#include namespace creaImageIO { @@ -27,22 +28,17 @@ namespace creaImageIO //===================================================================== bool DicomImageReader::CanRead(const std::string& filename) { - // std::cout << "## Reader "<SetLoadMode( GDCM_NAME_SPACE::LD_ALL); file->SetFileName(filename.c_str()); file->Load(); bool ok = file->IsReadable(); + if(!ok) + { + doc = (GDCM_NAME_SPACE::Document*)file; + ok = doc->IsReadable(); + } file->Delete(); return ok; } @@ -51,10 +47,6 @@ namespace creaImageIO //===================================================================== vtkImageData* DicomImageReader::ReadImage(const std::string& filename) { - // std::cout << "## Reader "<& v) { @@ -82,38 +74,45 @@ namespace creaImageIO //======================================================================== std::string irclean(const std::string& str) { - if (str == "GDCM::Unfound") - { - return ""; - } - if (str[str.size()-1]==' ') - { - return str.substr(0,str.size()-1); - } - if (str[str.size()-1]==0) - { - return str.substr(0,str.size()-1); - } + if(str.size() > 0) + { + if (str == "GDCM::Unfound") + { + return ""; + } + if (str[str.size()-1]==' ') + { + return str.substr(0,str.size()-1); + } + if (str[str.size()-1]==0) + { + return str.substr(0,str.size()-1); + } + } return str; } //======================================================================== - + //===================================================================== void DicomImageReader::ReadAttributes(const std::string& filename, std::map& attr) { - // std::cout << "DicomImageReader::ReadDicomInfo '"< file(GDCM_NAME_SPACE::File::New(), DicomImageReader::deleter()); + + GDCM_NAME_SPACE::Document *doc= GDCM_NAME_SPACE::File::New(); + doc->SetLoadMode( GDCM_NAME_SPACE::LD_ALL); + doc->SetFileName(filename.c_str()); + doc->Load(); file->SetLoadMode( GDCM_NAME_SPACE::LD_ALL); file->SetFileName(filename.c_str()); file->Load(); - if (file->IsReadable()) + if (file->IsReadable())// ||((GDCM_NAME_SPACE::Document*) file)->IsReadable()) { - std::map::iterator i; for (i=attr.begin();i!=attr.end();++i) { @@ -126,27 +125,29 @@ namespace creaImageIO else if ( i->first == "FullFileName" ) { i->second = filename; + } + else if ( i->first == "FullFileDirectory" ) + { + std::string::size_type last_pos = filename.find_last_of("//"); + //find first separator + i->second = filename.substr(0, last_pos); } else { uint16_t gr; uint16_t el; tree::AttributeDescriptor::GetDicomGroupElementFromKey(i->first,gr,el); - // GimmickMessage(2,"Key '"<first<<"' : "<GetEntryString(gr,el); i->second = irclean(val); - // GimmickMessage(2,"Key '"<first<<"' : "<