annotate CppClient/Instance.h @ 17:ae34bde412ae default tip

note
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 21 Dec 2016 11:05:16 +0100
parents f7379096e014
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
1 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
2 * Orthanc - A Lightweight, RESTful DICOM Store
12
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 7
diff changeset
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
0
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
4 * Department, University Hospital of Liege, Belgium
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
5 *
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
6 * This program is free software: you can redistribute it and/or
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
7 * modify it under the terms of the GNU General Public License as
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
8 * published by the Free Software Foundation, either version 3 of the
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
9 * License, or (at your option) any later version.
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
10 *
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
11 * In addition, as a special exception, the copyright holders of this
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
12 * program give permission to link the code of its release with the
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
13 * OpenSSL project's "OpenSSL" library (or with modified versions of it
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
14 * that use the same license as the "OpenSSL" library), and distribute
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
15 * the linked executables. You must obey the GNU General Public License
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
16 * in all respects for all of the code used other than "OpenSSL". If you
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
17 * modify file(s) with this exception, you may extend this exception to
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
18 * your version of the file(s), but you are not obligated to do so. If
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
19 * you do not wish to do so, delete this exception statement from your
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
20 * version. If you delete this exception statement from all source files
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
21 * in the program, then also delete it here.
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
22 *
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
23 * This program is distributed in the hope that it will be useful, but
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
24 * WITHOUT ANY WARRANTY; without even the implied warranty of
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
25 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
26 * General Public License for more details.
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
27 *
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
28 * You should have received a copy of the GNU General Public License
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
29 * along with this program. If not, see <http://www.gnu.org/licenses/>.
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
30 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
31
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
32
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
33 #pragma once
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
34
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
35 #include <string>
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
36 #include <json/value.h>
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
37
7
39730d6727f3 public enumerations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 5
diff changeset
38 #include "PublicEnumerations.h"
0
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
39 #include "OrthancClientException.h"
3
d5027f9f676a fix build
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 0
diff changeset
40 #include "../Orthanc/Core/IDynamicObject.h"
14
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 12
diff changeset
41 #include "../Orthanc/Core/Images/PngReader.h"
0
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
42
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
43 namespace OrthancClient
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
44 {
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
45 class OrthancConnection;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
46
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
47 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
48 * {summary}{Connection to an instance stored in %Orthanc.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
49 * {description}{This class encapsulates a connection to an image instance
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
50 * from a remote instance of %Orthanc.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
51 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
52 class LAAW_API Instance : public Orthanc::IDynamicObject
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
53 {
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
54 private:
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
55 const OrthancConnection& connection_;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
56 std::string id_;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
57 Json::Value tags_;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
58 std::auto_ptr<Orthanc::PngReader> reader_;
7
39730d6727f3 public enumerations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 5
diff changeset
59 ImageExtractionMode mode_;
0
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
60 std::auto_ptr<std::string> dicom_;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
61 std::string content_;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
62
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
63 void DownloadImage();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
64
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
65 void DownloadDicom();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
66
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
67 public:
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
68 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
69 * {summary}{Create a connection to some image instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
70 * {param}{connection The remote instance of %Orthanc.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
71 * {param}{id The %Orthanc identifier of the image instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
72 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
73 Instance(const OrthancConnection& connection,
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
74 const char* id);
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
75
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
76
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
77 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
78 * {summary}{Get the %Orthanc identifier of this identifier.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
79 * {returns}{The identifier.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
80 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
81 const char* GetId() const
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
82 {
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
83 return id_.c_str();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
84 }
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
85
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
86
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
87 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
88 * {summary}{Set the extraction mode for the 2D image corresponding to this instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
89 * {param}{mode The extraction mode.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
90 **/
7
39730d6727f3 public enumerations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 5
diff changeset
91 void SetImageExtractionMode(ImageExtractionMode mode);
0
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
92
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
93 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
94 * {summary}{Get the extraction mode for the 2D image corresponding to this instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
95 * {returns}{The extraction mode.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
96 **/
7
39730d6727f3 public enumerations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 5
diff changeset
97 ImageExtractionMode GetImageExtractionMode() const
0
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
98 {
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
99 return mode_;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
100 }
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
101
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
102
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
103 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
104 * {summary}{Get the string value of some DICOM tag of this instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
105 * {param}{tag The name of the tag of interest.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
106 * {returns}{The value of the tag.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
107 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
108 const char* GetTagAsString(const char* tag) const;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
109
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
110 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
111 * {summary}{Get the floating point value that is stored in some DICOM tag of this instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
112 * {param}{tag The name of the tag of interest.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
113 * {returns}{The value of the tag.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
114 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
115 float GetTagAsFloat(const char* tag) const;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
116
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
117 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
118 * {summary}{Get the integer value that is stored in some DICOM tag of this instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
119 * {param}{tag The name of the tag of interest.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
120 * {returns}{The value of the tag.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
121 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
122 int32_t GetTagAsInt(const char* tag) const;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
123
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
124
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
125 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
126 * {summary}{Get the width of the 2D image.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
127 * {description}{Get the width of the 2D image that is encoded by this DICOM instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
128 * {returns}{The width.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
129 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
130 uint32_t GetWidth();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
131
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
132 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
133 * {summary}{Get the height of the 2D image.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
134 * {description}{Get the height of the 2D image that is encoded by this DICOM instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
135 * {returns}{The height.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
136 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
137 uint32_t GetHeight();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
138
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
139 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
140 * {summary}{Get the number of bytes between two lines of the image (pitch).}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
141 * {description}{Get the number of bytes between two lines of the image in the memory buffer returned by GetBuffer(). This value depends on the extraction mode for the image.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
142 * {returns}{The pitch.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
143 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
144 uint32_t GetPitch();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
145
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
146 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
147 * {summary}{Get the format of the pixels of the 2D image.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
148 * {description}{Return the memory layout that is used for the 2D image that is encoded by this DICOM instance. This value depends on the extraction mode for the image.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
149 * {returns}{The pixel format.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
150 **/
7
39730d6727f3 public enumerations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 5
diff changeset
151 PixelFormat GetPixelFormat();
0
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
152
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
153 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
154 * {summary}{Access the memory buffer in which the raw pixels of the 2D image are stored.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
155 * {returns}{A pointer to the memory buffer.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
156 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
157 const void* GetBuffer();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
158
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
159 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
160 * {summary}{Access the memory buffer in which the raw pixels of some line of the 2D image are stored.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
161 * {param}{y The line of interest.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
162 * {returns}{A pointer to the memory buffer.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
163 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
164 const void* GetBuffer(uint32_t y);
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
165
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
166 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
167 * {summary}{Get the size of the DICOM file corresponding to this instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
168 * {returns}{The file size.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
169 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
170 const uint64_t GetDicomSize();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
171
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
172 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
173 * {summary}{Get a pointer to the content of the DICOM file corresponding to this instance.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
174 * {returns}{The DICOM file.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
175 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
176 const void* GetDicom();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
177
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
178 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
179 * {summary}{Discard the downloaded 2D image, so as to make room in memory.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
180 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
181 void DiscardImage();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
182
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
183 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
184 * {summary}{Discard the downloaded DICOM file, so as to make room in memory.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
185 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
186 void DiscardDicom();
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
187
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
188 LAAW_API_INTERNAL void SplitVectorOfFloats(std::vector<float>& target,
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
189 const char* tag);
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
190
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
191 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
192 * {summary}{Load a raw tag from the DICOM file.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
193 * {param}{path The path to the tag of interest (e.g. "0020-000d").}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
194 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
195 void LoadTagContent(const char* path);
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
196
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
197 /**
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
198 * {summary}{Return the value of the raw tag that was loaded by LoadContent.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
199 * {returns}{The tag value.}
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
200 **/
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
201 const char* GetLoadedTagContent() const;
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
202 };
ebc1e38ef615 initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
203 }