comparison OrthancCppClient/Series.h @ 479:0cd977e94479

initial commit of the c++ client
author Sebastien Jodogne <s.jodogne@gmail.com>
date Tue, 16 Jul 2013 09:08:09 +0200
parents
children 482cde3f3c14
comparison
equal deleted inserted replaced
478:888f8a778e70 479:0cd977e94479
1 /**
2 * Orthanc - A Lightweight, RESTful DICOM Store
3 * Copyright (C) 2012-2013 Medical Physics Department, CHU of Liege,
4 * Belgium
5 *
6 * This program is free software: you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License as
8 * published by the Free Software Foundation, either version 3 of the
9 * License, or (at your option) any later version.
10 *
11 * In addition, as a special exception, the copyright holders of this
12 * program give permission to link the code of its release with the
13 * OpenSSL project's "OpenSSL" library (or with modified versions of it
14 * that use the same license as the "OpenSSL" library), and distribute
15 * the linked executables. You must obey the GNU General Public License
16 * in all respects for all of the code used other than "OpenSSL". If you
17 * modify file(s) with this exception, you may extend this exception to
18 * your version of the file(s), but you are not obligated to do so. If
19 * you do not wish to do so, delete this exception statement from your
20 * version. If you delete this exception statement from all source files
21 * in the program, then also delete it here.
22 *
23 * This program is distributed in the hope that it will be useful, but
24 * WITHOUT ANY WARRANTY; without even the implied warranty of
25 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
26 * General Public License for more details.
27 *
28 * You should have received a copy of the GNU General Public License
29 * along with this program. If not, see <http://www.gnu.org/licenses/>.
30 **/
31
32
33 #pragma once
34
35 #include "Instance.h"
36
37 #include "../Core/MultiThreading/ArrayFilledByThreads.h"
38 #include "../Core/MultiThreading/ThreadedCommandProcessor.h"
39
40 namespace OrthancClient
41 {
42 class Series : public Orthanc::IDynamicObject, private Orthanc::ArrayFilledByThreads::IFiller
43 {
44 private:
45 enum Status3DImage
46 {
47 Status3DImage_NotTested,
48 Status3DImage_True,
49 Status3DImage_False
50 };
51
52 const OrthancConnection& connection_;
53 std::string id_;
54 Json::Value series_;
55 Orthanc::ArrayFilledByThreads instances_;
56 Status3DImage status_;
57
58 void Check3DImage();
59
60 bool Is3DImageInternal();
61
62 void ReadSeries();
63
64 virtual size_t GetFillerSize()
65 {
66 return series_["Instances"].size();
67 }
68
69 virtual Orthanc::IDynamicObject* GetFillerItem(size_t index);
70
71 void Load3DImage(void* target,
72 Orthanc::PixelFormat format,
73 size_t lineStride,
74 size_t stackStride,
75 Orthanc::ThreadedCommandProcessor::IListener* listener);
76
77 public:
78 Series(const OrthancConnection& connection,
79 const std::string& id);
80
81 void Reload()
82 {
83 instances_.Reload();
84 }
85
86 bool Is3DImage();
87
88 unsigned int GetInstanceCount();
89
90 Instance& GetInstance(unsigned int index);
91
92 const std::string& GetId() const
93 {
94 return id_;
95 }
96
97 std::string GetUrl() const;
98
99 unsigned int GetWidth();
100
101 unsigned int GetHeight();
102
103 void GetVoxelSize(float& sizeX, float& sizeY, float& sizeZ);
104
105 std::string GetMainDicomTag(const char* tag,
106 const char* defaultValue) const;
107
108 void Load3DImage(void* target,
109 Orthanc::PixelFormat format,
110 size_t lineStride,
111 size_t stackStride,
112 Orthanc::ThreadedCommandProcessor::IListener& listener)
113 {
114 Load3DImage(target, format, lineStride, stackStride, &listener);
115 }
116
117 void Load3DImage(void* target,
118 Orthanc::PixelFormat format,
119 size_t lineStride,
120 size_t stackStride)
121 {
122 Load3DImage(target, format, lineStride, stackStride, NULL);
123 }
124 };
125 }