Mercurial > hg > orthanc-wsi
annotate Framework/ImagedVolumeParameters.cpp @ 72:ea6309f70f1f
new file: Orthanc/Core/Cache/LeastRecentlyUsedIndex.h
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Mon, 28 Nov 2016 10:40:48 +0100 |
parents | 7a3853d51c45 |
children | ff0ef01c332c |
rev | line source |
---|---|
0 | 1 /** |
2 * Orthanc - A Lightweight, RESTful DICOM Store | |
3 * Copyright (C) 2012-2016 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 Affero General Public License | |
8 * as published by the Free Software Foundation, either version 3 of | |
9 * the 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 * Affero General Public License for more details. | |
15 * | |
16 * You should have received a copy of the GNU Affero General Public License | |
17 * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
18 **/ | |
19 | |
20 | |
16
7a88c614be04
preparing for precompiled headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
21 #include "PrecompiledHeadersWSI.h" |
0 | 22 #include "ImagedVolumeParameters.h" |
23 | |
59
7a3853d51c45
Move "Framework/Orthanc/" as "Resources/Orthanc/"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
16
diff
changeset
|
24 #include "../Resources/Orthanc/Core/OrthancException.h" |
0 | 25 |
26 namespace OrthancWSI | |
27 { | |
28 ImagedVolumeParameters::ImagedVolumeParameters() | |
29 { | |
30 // Typical parameters of a specimen millimeters | |
31 width_ = 15; | |
32 height_ = 15; | |
33 depth_ = 1; | |
34 offsetX_ = 20; | |
35 offsetY_ = 40; | |
36 } | |
37 | |
38 | |
39 void ImagedVolumeParameters::SetWidth(float width) | |
40 { | |
41 if (width <= 0) | |
42 { | |
43 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); | |
44 } | |
45 | |
46 width_ = width; | |
47 } | |
48 | |
49 | |
50 void ImagedVolumeParameters::SetHeight(float height) | |
51 { | |
52 if (height <= 0) | |
53 { | |
54 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); | |
55 } | |
56 | |
57 height_ = height; | |
58 } | |
59 | |
60 | |
61 void ImagedVolumeParameters::SetDepth(float depth) | |
62 { | |
63 if (depth <= 0) | |
64 { | |
65 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); | |
66 } | |
67 | |
68 depth_ = depth; | |
69 } | |
70 | |
71 | |
72 void ImagedVolumeParameters::GetLocation(float& physicalX, | |
73 float& physicalY, | |
74 unsigned int imageX, | |
75 unsigned int imageY, | |
76 unsigned int totalWidth, | |
77 unsigned int totalHeight) const | |
78 { | |
79 if (imageX >= totalWidth || | |
80 imageY >= totalHeight) | |
81 { | |
82 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); | |
83 } | |
84 | |
85 // WARNING: The physical X/Y axes are switched wrt. the image X/Y | |
86 physicalX = offsetX_ - GetHeight() * static_cast<float>(imageX) / static_cast<float>(totalWidth); | |
87 physicalY = offsetY_ - GetWidth() * static_cast<float>(imageY) / static_cast<float>(totalHeight); | |
88 } | |
89 } |