1834
|
1 /**
|
|
2 * Orthanc - A Lightweight, RESTful DICOM Store
|
|
3 * Copyright (C) 2012-2015 Sebastien Jodogne, Medical Physics
|
|
4 * Department, University Hospital of Liege, 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 * This program is distributed in the hope that it will be useful, but
|
|
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
14 * General Public License for more details.
|
|
15 *
|
|
16 * You should have received a copy of the GNU General Public License
|
|
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
18 **/
|
|
19
|
|
20
|
|
21 #include "OrthancImageWrapper.h"
|
|
22
|
|
23 #include <stdexcept>
|
|
24
|
|
25 namespace OrthancPlugins
|
|
26 {
|
|
27 OrthancImageWrapper::OrthancImageWrapper(OrthancPluginContext* context,
|
|
28 OrthancPluginPixelFormat format,
|
|
29 uint32_t width,
|
|
30 uint32_t height) :
|
1836
|
31 context_(context),
|
|
32 slope_(1),
|
|
33 intercept_(0),
|
|
34 rowPixelSpacing_(1),
|
|
35 columnPixelSpacing_(1)
|
1834
|
36 {
|
|
37 image_ = OrthancPluginCreateImage(context_, format, width, height);
|
|
38 if (image_ == NULL)
|
|
39 {
|
|
40 throw std::runtime_error("Cannot create an image");
|
|
41 }
|
|
42 }
|
|
43
|
|
44
|
1836
|
45 OrthancImageWrapper::OrthancImageWrapper(OrthancPluginContext* context,
|
|
46 GdcmImageDecoder& decoder,
|
|
47 unsigned int frameIndex) :
|
|
48 context_(context),
|
|
49 image_(decoder.Decode(context, frameIndex)),
|
|
50 slope_(decoder.GetSlope()),
|
|
51 intercept_(decoder.GetIntercept()),
|
|
52 rowPixelSpacing_(decoder.GetRowPixelSpacing()),
|
|
53 columnPixelSpacing_(decoder.GetColumnPixelSpacing())
|
|
54 {
|
|
55 }
|
|
56
|
|
57
|
|
58
|
1834
|
59 OrthancImageWrapper::~OrthancImageWrapper()
|
|
60 {
|
|
61 if (image_ != NULL)
|
|
62 {
|
|
63 OrthancPluginFreeImage(context_, image_);
|
|
64 }
|
|
65 }
|
|
66
|
|
67
|
|
68 OrthancPluginImage* OrthancImageWrapper::Release()
|
|
69 {
|
|
70 OrthancPluginImage* tmp = image_;
|
|
71 image_ = NULL;
|
|
72 return tmp;
|
|
73 }
|
|
74
|
|
75
|
|
76 uint32_t OrthancImageWrapper::GetWidth()
|
|
77 {
|
|
78 return OrthancPluginGetImageWidth(context_, image_);
|
|
79 }
|
|
80
|
|
81
|
|
82 uint32_t OrthancImageWrapper::GetHeight()
|
|
83 {
|
|
84 return OrthancPluginGetImageHeight(context_, image_);
|
|
85 }
|
|
86
|
|
87
|
|
88 uint32_t OrthancImageWrapper::GetPitch()
|
|
89 {
|
|
90 return OrthancPluginGetImagePitch(context_, image_);
|
|
91 }
|
|
92
|
|
93
|
|
94 OrthancPluginPixelFormat OrthancImageWrapper::GetFormat()
|
|
95 {
|
|
96 return OrthancPluginGetImagePixelFormat(context_, image_);
|
|
97 }
|
|
98
|
|
99
|
|
100 char* OrthancImageWrapper::GetBuffer()
|
|
101 {
|
|
102 return reinterpret_cast<char*>(OrthancPluginGetImageBuffer(context_, image_));
|
|
103 }
|
|
104 }
|