X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=Example%2FPrintHeader.cxx;h=eb64a3ffd0a6edcbca9b07a7d03f03ce7de7ace9;hb=a9921455f3f7797886480f3185054fc9c59d96bc;hp=c8ec5d6ca433e5eefe57971bc2a9eeb7159fc5f5;hpb=4c8c80589b3770976ea27fc03b290b97db5da3e6;p=gdcm.git diff --git a/Example/PrintHeader.cxx b/Example/PrintHeader.cxx index c8ec5d6c..eb64a3ff 100644 --- a/Example/PrintHeader.cxx +++ b/Example/PrintHeader.cxx @@ -1,56 +1,72 @@ +/*========================================================================= + + Program: gdcm + Module: $RCSfile: PrintHeader.cxx,v $ + Language: C++ + Date: $Date: 2005/02/01 10:34:59 $ + Version: $Revision: 1.18 $ + + 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 "gdcmFile.h" +#include "gdcmDebug.h" + #include -#include "gdcm.h" int main(int argc, char* argv[]) { - bool dropPriv = false; std::string fileName; - if (argc == 1) { - std::cout << argv[0] << - " fileName" << std::endl << - " [nopriv] if you don't want to print Shadow groups" << std::endl; + if (argc == 1) + { + std::cout << argv[0] << " fileName printLevel debug" << std::endl; } - if (argc > 1) { + if (argc > 1) + { fileName=argv[1]; - } else { + } + else + { fileName += GDCM_DATA_ROOT; fileName += "/test.acr"; } - - for (int j=0;jGetHeader(); - - if (argc > 2) { + + if (argc > 3) + gdcm::Debug::DebugOn(); + + gdcm::File *e1 = new gdcm::File( fileName.c_str() ); + + if (argc > 2) + { int level = atoi(argv[2]); e1->SetPrintLevel(level); } - e1->Print(); - - std::cout << "\n\n" << std::endl; - std::string transferSyntaxName = e1->GetTransfertSyntaxName(); - std::cout << " TransferSyntaxName= [" << transferSyntaxName << "]" << std::endl; - - if ( transferSyntaxName != "Implicit VR - Little Endian" - && transferSyntaxName != "Explicit VR - Little Endian" - && transferSyntaxName != "Deflated Explicit VR - Little Endian" - && transferSyntaxName != "Explicit VR - Big Endian" - && transferSyntaxName != "Uncompressed ACR-NEMA" ) - { - std::cout << std::endl << "===========================================" - << std::endl; - e2->ParsePixelData(); - std::cout << std::endl << "===========================================" - << std::endl; - } - + e1->Print(); + + std::cout << "\n\n" << std::endl; + + if ( e1->GetEntryValue(0x0002,0x0010) == gdcm::GDCM_NOTLOADED ) + { + std::cout << "Transfer Syntax not loaded. " << std::endl + << "Better you increase MAX_SIZE_LOAD_ELEMENT_VALUE" + << std::endl; + return 0; + } + + std::string transferSyntaxName = e1->GetTransferSyntaxName(); + std::cout << " TransferSyntaxName= [" << transferSyntaxName << "]" + << std::endl; + std::cout << " SwapCode= " << e1->GetSwapCode() << std::endl; + if(e1->IsReadable()) std::cout <