annotate Samples/Basic/main.cpp @ 2:8f22ed9d48d5

cont
author Sebastien Jodogne <s.jodogne@gmail.com>
date Mon, 01 Jun 2015 13:59:12 +0200
parents
children 6d59828e2662
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
1 /**
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
2 * Orthanc - A Lightweight, RESTful DICOM Store
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
3 * Copyright (C) 2012-2015 Sebastien Jodogne, Medical Physics
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
4 * Department, University Hospital of Liege, Belgium
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
5 *
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
6 * This program is free software: you can redistribute it and/or
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
7 * modify it under the terms of the GNU General Public License as
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
8 * published by the Free Software Foundation, either version 3 of the
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
9 * License, or (at your option) any later version.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
10 *
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
11 * This program is distributed in the hope that it will be useful, but
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
14 * General Public License for more details.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
15 *
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
16 * You should have received a copy of the GNU General Public License
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
18 **/
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
19
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
20
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
21 #include <iostream>
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
22 #include <orthanc/OrthancCppClient.h>
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
23
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
24 int main()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
25 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
26 try
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
27 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
28 // The following explicit initialization is not required, except
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
29 // if you wish to specify the full path to the shared library
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
30 OrthancClient::Initialize();
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
31
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
32 // Display the content of the local Orthanc instance
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
33 OrthancClient::OrthancConnection orthanc("http://localhost:8042");
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
34
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
35 for (unsigned int i = 0; i < orthanc.GetPatientCount(); i++)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
36 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
37 OrthancClient::Patient patient(orthanc.GetPatient(i));
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
38 std::cout << "Patient: " << patient.GetId() << std::endl;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
39
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
40 for (unsigned int j = 0; j < patient.GetStudyCount(); j++)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
41 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
42 OrthancClient::Study study(patient.GetStudy(j));
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
43 std::cout << " Study: " << study.GetId() << std::endl;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
44
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
45 for (unsigned int k = 0; k < study.GetSeriesCount(); k++)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
46 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
47 OrthancClient::Series series(study.GetSeries(k));
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
48 std::cout << " Series: " << series.GetId() << std::endl;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
49
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
50 if (series.Is3DImage())
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
51 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
52 std::cout << " This is a 3D image whose voxel size is "
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
53 << series.GetVoxelSizeX() << " x "
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
54 << series.GetVoxelSizeY() << " x "
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
55 << series.GetVoxelSizeZ() << ", and slice thickness is "
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
56 << series.GetSliceThickness() << std::endl;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
57 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
58
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
59 for (unsigned int l = 0; l < series.GetInstanceCount(); l++)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
60 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
61 std::cout << " Instance: " << series.GetInstance(l).GetId() << std::endl;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
62
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
63 // Load and display some raw DICOM tag
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
64 series.GetInstance(l).LoadTagContent("0020-000d");
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
65 std::cout << " SOP instance UID: " << series.GetInstance(l).GetLoadedTagContent() << std::endl;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
66 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
67 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
68 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
69 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
70
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
71 OrthancClient::Finalize();
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
72
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
73 return 0;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
74 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
75 catch (OrthancClient::OrthancClientException& e)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
76 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
77 std::cerr << "EXCEPTION: [" << e.What() << "]" << std::endl;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
78 return -1;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
79 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
80 }