1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
#include <iostream>
#include "odil/Association.h"
#include "odil/DataSet.h"
#include "odil/FindSCU.h"
#include "odil/GetSCU.h"
#include "odil/registry.h"
void print_informations(std::shared_ptr<odil::DataSet const> response)
{
auto const name = response->has("PatientName")?
response->as_string("PatientName", 0):"(no name)";
auto const study = response->has("StudyDescription")?
response->as_string("StudyDescription", 0):"(no study description)";
auto const series = response->has("SeriesDescription")?
response->as_string("SeriesDescription", 0):"(no series description)";
auto const instance = response->has("InstanceNumber")?
response->as_int("InstanceNumber", 0):(-1);
std::cout
<< name << ": " << study << " / " << series << ": " << instance << "\n";
}
int main()
{
odil::Association association;
association.set_peer_host("184.73.255.26");
association.set_peer_port(11112);
association.update_parameters()
.set_calling_ae_title("myself")
.set_called_ae_title("AWSPIXELMEDPUB")
.set_presentation_contexts({
{
odil::registry::StudyRootQueryRetrieveInformationModelFind,
{ odil::registry::ImplicitVRLittleEndian },
odil::AssociationParameters::PresentationContext::Role::SCU
},
{
odil::registry::StudyRootQueryRetrieveInformationModelGet,
{ odil::registry::ImplicitVRLittleEndian },
odil::AssociationParameters::PresentationContext::Role::SCU
},
{
odil::registry::MRImageStorage,
{ odil::registry::ImplicitVRLittleEndian },
odil::AssociationParameters::PresentationContext::Role::SCP
},
{
odil::registry::Verification,
{ odil::registry::ImplicitVRLittleEndian },
odil::AssociationParameters::PresentationContext::Role::SCU
}
});
association.associate();
odil::FindSCU find_scu(association);
find_scu.set_affected_sop_class(
odil::registry::StudyRootQueryRetrieveInformationModelFind);
auto query = std::make_shared<odil::DataSet>();
query->add("QueryRetrieveLevel", { "STUDY" });
query->add("StudyInstanceUID");
auto const studies = find_scu.find(query);
std::shared_ptr<odil::DataSet> series;
for(auto const & study: studies)
{
if(!study->has("StudyInstanceUID"))
{
continue;
}
query->clear();
query->add("QueryRetrieveLevel", {"SERIES"});
query->add("Modality", {"MR"});
query->add("StudyInstanceUID", study->as_string("StudyInstanceUID"));
query->add("SeriesInstanceUID");
auto const study_series = find_scu.find(query);
if(!study_series.empty())
{
series = study_series[0];
break;
}
}
odil::GetSCU get_scu(association);
get_scu.set_affected_sop_class(
odil::registry::StudyRootQueryRetrieveInformationModelGet);
query->clear();
query->add("QueryRetrieveLevel", { "SERIES" });
query->add("StudyInstanceUID", (*series)["StudyInstanceUID"]);
query->add("SeriesInstanceUID", (*series)["SeriesInstanceUID"]);
std::cout << "--------\n";
std::cout << "Callback\n";
std::cout << "--------\n\n";
get_scu.get(query, print_informations);
std::cout << "\n";
std::cout << "------\n";
std::cout << "vector\n";
std::cout << "------\n\n";
auto const result = get_scu.get(query);
for(auto const & dataset: result)
{
print_informations(dataset);
}
association.release();
}
|