123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- /*=========================================================================
- Library: CTK
- Copyright (c) Kitware Inc.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0.txt
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- =========================================================================*/
- // Qt includes
- #include <QCoreApplication>
- #include <QDebug>
- #include <QStringList>
- #include <QVariant>
- // ctkDICOMCore includes
- #include "ctkDICOMDatabase.h"
- #include "ctkDICOMQuery.h"
- #include "ctkDICOMRetrieve.h"
- #include "ctkDICOMTester.h"
- // STD includes
- #include <iostream>
- void ctkDICOMRetrieveTest2PrintUsage()
- {
- std::cout << " ctkDICOMRetrieveTest2 images" << std::endl;
- }
- // Test on a real local database
- int ctkDICOMRetrieveTest2( int argc, char * argv [] )
- {
- QCoreApplication app(argc, argv);
- ctkDICOMTester tester;
- tester.startDCMQRSCP();
-
- QStringList arguments = app.arguments();
- arguments.pop_front(); // remove application name
- arguments.pop_front(); // remove test name
- if (!arguments.count())
- {
- ctkDICOMRetrieveTest2PrintUsage();
- return EXIT_FAILURE;
- }
- tester.storeData(arguments);
- ctkDICOMDatabase queryDatabase;
- ctkDICOMQuery query;
- query.setCallingAETitle("CTK_AE");
- query.setCalledAETitle("CTK_AE");
- query.setHost("localhost");
- query.setPort(tester.dcmqrscpPort());
- bool res = query.query(queryDatabase);
- if (!res)
- {
- std::cout << "ctkDICOMQuery::query() failed" << std::endl;
- return EXIT_FAILURE;
- }
- if (query.studyInstanceUIDQueried().count() == 0)
- {
- std::cout << "ctkDICOMQuery::query() failed."
- << "No study instance retrieved" << std::endl;
- return EXIT_FAILURE;
- }
- QSharedPointer<ctkDICOMDatabase> retrieveDatabase(new ctkDICOMDatabase);
- retrieveDatabase->openDatabase( "./ctkDICOM.sql" );
- ctkDICOMRetrieve retrieve;
- retrieve.setCallingAETitle("CTK_AE");
- retrieve.setCalledAETitle("CTK_AE");
- retrieve.setCalledPort(tester.dcmqrscpPort());
- retrieve.setHost("localhost");
- retrieve.setMoveDestinationAETitle("CTK_CLIENT_AE");
- retrieve.setRetrieveDatabase(retrieveDatabase);
- foreach(const QString& study, query.studyInstanceUIDQueried())
- {
- bool res = retrieve.retrieveStudy(study);
- if (!res)
- {
- std::cout << "ctkDICOMRetrieve::retrieveStudy() failed. "
- << "Study " << qPrintable(study) << " can't be retrieved"
- << std::endl;
- return EXIT_FAILURE;
- }
- }
- return EXIT_SUCCESS;
- }
|