Mercurial > hg > orthanc-stone
annotate Applications/Samples/Sdl/SingleFrameViewer/SdlSimpleViewer.cpp @ 1798:41f3872bd7d2
create angle tool and delete measure tool
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Thu, 20 May 2021 11:10:14 +0200 |
parents | 013dec434a84 |
children | 1125793d82d3 |
rev | line source |
---|---|
1458
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
1 /** |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
2 * Stone of Orthanc |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
4 * Department, University Hospital of Liege, Belgium |
1739
9ac2a65d4172
upgrade to year 2021
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1596
diff
changeset
|
5 * Copyright (C) 2017-2021 Osimis S.A., Belgium |
1458
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
6 * |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
7 * This program is free software: you can redistribute it and/or |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
8 * modify it under the terms of the GNU Affero General Public License |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
9 * as published by the Free Software Foundation, either version 3 of |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
10 * the License, or (at your option) any later version. |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
11 * |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
12 * This program is distributed in the hope that it will be useful, but |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
13 * WITHOUT ANY WARRANTY; without even the implied warranty of |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
15 * Affero General Public License for more details. |
1596
4fb8fdf03314
removed annoying whitespace
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1591
diff
changeset
|
16 * |
1458
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
17 * You should have received a copy of the GNU Affero General Public License |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
18 * along with this program. If not, see <http://www.gnu.org/licenses/>. |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
19 **/ |
828a9b4ee1b7
added missing copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1457
diff
changeset
|
20 |
1368 | 21 |
22 #include "SdlSimpleViewerApplication.h" | |
1387
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
23 #include "../SdlHelpers.h" |
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
24 #include "../../Common/SampleHelpers.h" |
1368 | 25 |
1542 | 26 #include "../../../../OrthancStone/Sources/Loaders/GenericLoadersContext.h" |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
27 #include "../../../../OrthancStone/Sources/Scene2DViewport/AngleMeasureTool.h" |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
28 #include "../../../../OrthancStone/Sources/Scene2DViewport/LineMeasureTool.h" |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
29 #include "../../../../OrthancStone/Sources/Scene2DViewport/UndoStack.h" |
1560
b4ccd4963d37
fix sdl and wasm samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1542
diff
changeset
|
30 #include "../../../../OrthancStone/Sources/StoneEnumerations.h" |
1542 | 31 #include "../../../../OrthancStone/Sources/StoneException.h" |
32 #include "../../../../OrthancStone/Sources/StoneInitialization.h" | |
1560
b4ccd4963d37
fix sdl and wasm samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1542
diff
changeset
|
33 #include "../../../../OrthancStone/Sources/Viewport/DefaultViewportInteractor.h" |
1591
5887a4f8594b
moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1576
diff
changeset
|
34 #include "../../../Platforms/Sdl/SdlViewport.h" |
1368 | 35 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
36 #include <EmbeddedResources.h> |
1507
169adf9090a6
replacing deprecated std::auto_ptr by std::unique_ptr
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1458
diff
changeset
|
37 #include <Compatibility.h> // For std::unique_ptr<> |
1457 | 38 #include <OrthancException.h> |
1387
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
39 |
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
40 #include <boost/program_options.hpp> |
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
41 #include <SDL.h> |
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
42 |
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
43 #include <string> |
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
44 |
1368 | 45 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
46 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
47 #if 1 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
48 #include "../../../../OrthancStone/Sources/Scene2D/MacroSceneLayer.h" |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
49 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
50 #include <boost/math/constants/constants.hpp> |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
51 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
52 static const double HANDLE_SIZE = 10.0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
53 static const double PI = boost::math::constants::pi<double>(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
54 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
55 namespace OrthancStone |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
56 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
57 class AnnotationsOverlay : public boost::noncopyable |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
58 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
59 public: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
60 enum Tool |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
61 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
62 Tool_Edit, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
63 Tool_None, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
64 Tool_Segment, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
65 Tool_Angle, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
66 Tool_Circle, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
67 Tool_Erase |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
68 }; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
69 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
70 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
71 class Measure; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
72 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
73 class Primitive : public boost::noncopyable |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
74 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
75 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
76 bool modified_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
77 Measure& parentMeasure_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
78 Color color_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
79 Color hoverColor_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
80 bool isHover_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
81 int depth_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
82 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
83 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
84 Primitive(Measure& parentMeasure, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
85 int depth) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
86 modified_(true), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
87 parentMeasure_(parentMeasure), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
88 color_(192, 192, 192), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
89 hoverColor_(0, 255, 0), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
90 isHover_(false), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
91 depth_(depth) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
92 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
93 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
94 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
95 virtual ~Primitive() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
96 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
97 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
98 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
99 Measure& GetParentMeasure() const |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
100 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
101 return parentMeasure_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
102 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
103 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
104 int GetDepth() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
105 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
106 return depth_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
107 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
108 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
109 void SetHover(bool hover) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
110 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
111 if (hover != isHover_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
112 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
113 isHover_ = hover; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
114 modified_ = true; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
115 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
116 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
117 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
118 bool IsHover() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
119 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
120 return isHover_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
121 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
122 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
123 void SetModified(bool modified) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
124 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
125 modified_ = modified; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
126 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
127 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
128 bool IsModified() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
129 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
130 return modified_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
131 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
132 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
133 void SetColor(const Color& color) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
134 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
135 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
136 color_ = color; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
137 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
138 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
139 void SetHoverColor(const Color& color) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
140 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
141 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
142 hoverColor_ = color; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
143 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
144 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
145 const Color& GetColor() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
146 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
147 return color_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
148 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
149 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
150 const Color& GetHoverColor() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
151 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
152 return hoverColor_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
153 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
154 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
155 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
156 const Scene2D& scene) const = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
157 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
158 // Always called, even if not modified |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
159 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
160 const Scene2D& scene) = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
161 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
162 // Only called if modified |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
163 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
164 const Scene2D& scene) = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
165 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
166 virtual void MovePreview(const ScenePoint2D& delta) = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
167 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
168 virtual void MoveDone(const ScenePoint2D& delta) = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
169 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
170 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
171 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
172 class Measure : public boost::noncopyable |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
173 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
174 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
175 typedef std::list<Primitive*> Primitives; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
176 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
177 AnnotationsOverlay& that_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
178 Primitives primitives_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
179 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
180 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
181 Measure(AnnotationsOverlay& that) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
182 that_(that) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
183 { |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
184 that.AddMeasure(this); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
185 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
186 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
187 virtual ~Measure() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
188 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
189 for (Primitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
190 { |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
191 that_.DeletePrimitive(*it); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
192 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
193 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
194 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
195 Primitive* AddPrimitive(Primitive* primitive) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
196 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
197 if (primitive == NULL) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
198 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
199 throw Orthanc::OrthancException(Orthanc::ErrorCode_NullPointer); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
200 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
201 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
202 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
203 assert(that_.primitives_.find(primitive) == that_.primitives_.end()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
204 primitives_.push_back(primitive); // For automated deallocation |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
205 that_.primitives_.insert(primitive); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
206 return primitive; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
207 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
208 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
209 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
210 template <typename T> |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
211 T& AddTypedPrimitive(T* primitive) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
212 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
213 AddPrimitive(primitive); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
214 return *primitive; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
215 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
216 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
217 virtual void SignalMove(Primitive& primitive) = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
218 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
219 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
220 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
221 class Handle : public Primitive |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
222 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
223 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
224 ScenePoint2D center_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
225 ScenePoint2D delta_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
226 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
227 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
228 explicit Handle(Measure& parentMeasure, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
229 const ScenePoint2D& center) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
230 Primitive(parentMeasure, 0), // Highest priority |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
231 center_(center), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
232 delta_(0, 0) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
233 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
234 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
235 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
236 void SetSize(unsigned int size) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
237 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
238 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
239 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
240 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
241 void SetCenter(const ScenePoint2D& center) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
242 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
243 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
244 center_ = center; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
245 delta_ = ScenePoint2D(0, 0); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
246 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
247 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
248 ScenePoint2D GetCenter() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
249 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
250 return center_ + delta_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
251 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
252 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
253 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
254 const Scene2D& scene) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
255 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
256 const double zoom = scene.GetSceneToCanvasTransform().ComputeZoom(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
257 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
258 double dx = (center_.GetX() + delta_.GetX() - p.GetX()) * zoom; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
259 double dy = (center_.GetY() + delta_.GetY() - p.GetY()) * zoom; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
260 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
261 return (std::abs(dx) <= HANDLE_SIZE / 2.0 && |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
262 std::abs(dy) <= HANDLE_SIZE / 2.0); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
263 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
264 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
265 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
266 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
267 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
268 const double zoom = scene.GetSceneToCanvasTransform().ComputeZoom(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
269 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
270 // TODO: take DPI into account |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
271 double x1 = center_.GetX() + delta_.GetX() - (HANDLE_SIZE / 2.0) / zoom; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
272 double y1 = center_.GetY() + delta_.GetY() - (HANDLE_SIZE / 2.0) / zoom; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
273 double x2 = center_.GetX() + delta_.GetX() + (HANDLE_SIZE / 2.0) / zoom; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
274 double y2 = center_.GetY() + delta_.GetY() + (HANDLE_SIZE / 2.0) / zoom; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
275 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
276 PolylineSceneLayer::Chain chain; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
277 chain.reserve(4); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
278 chain.push_back(ScenePoint2D(x1, y1)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
279 chain.push_back(ScenePoint2D(x2, y1)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
280 chain.push_back(ScenePoint2D(x2, y2)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
281 chain.push_back(ScenePoint2D(x1, y2)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
282 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
283 if (IsHover()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
284 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
285 polyline.AddChain(chain, true /* closed */, GetHoverColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
286 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
287 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
288 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
289 polyline.AddChain(chain, true /* closed */, GetColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
290 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
291 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
292 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
293 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
294 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
295 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
296 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
297 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
298 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
299 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
300 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
301 delta_ = delta; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
302 GetParentMeasure().SignalMove(*this); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
303 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
304 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
305 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
306 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
307 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
308 center_ = center_ + delta; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
309 delta_ = ScenePoint2D(0, 0); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
310 GetParentMeasure().SignalMove(*this); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
311 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
312 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
313 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
314 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
315 class Segment : public Primitive |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
316 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
317 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
318 ScenePoint2D p1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
319 ScenePoint2D p2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
320 ScenePoint2D delta_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
321 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
322 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
323 Segment(Measure& parentMeasure, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
324 const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
325 const ScenePoint2D& p2) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
326 Primitive(parentMeasure, 1), // Can only be selected if no handle matches |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
327 p1_(p1), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
328 p2_(p2), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
329 delta_(0, 0) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
330 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
331 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
332 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
333 void SetPosition(const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
334 const ScenePoint2D& p2) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
335 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
336 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
337 p1_ = p1; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
338 p2_ = p2; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
339 delta_ = ScenePoint2D(0, 0); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
340 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
341 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
342 ScenePoint2D GetPosition1() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
343 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
344 return p1_ + delta_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
345 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
346 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
347 ScenePoint2D GetPosition2() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
348 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
349 return p2_ + delta_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
350 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
351 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
352 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
353 const Scene2D& scene) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
354 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
355 const double zoom = scene.GetSceneToCanvasTransform().ComputeZoom(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
356 return (ScenePoint2D::SquaredDistancePtSegment(p1_ + delta_, p2_ + delta_, p) * zoom * zoom <= |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
357 (HANDLE_SIZE / 2.0) * (HANDLE_SIZE / 2.0)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
358 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
359 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
360 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
361 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
362 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
363 PolylineSceneLayer::Chain chain; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
364 chain.reserve(2); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
365 chain.push_back(p1_ + delta_); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
366 chain.push_back(p2_ + delta_); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
367 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
368 if (IsHover()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
369 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
370 polyline.AddChain(chain, false /* closed */, GetHoverColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
371 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
372 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
373 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
374 polyline.AddChain(chain, false /* closed */, GetColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
375 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
376 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
377 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
378 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
379 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
380 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
381 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
382 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
383 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
384 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
385 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
386 delta_ = delta; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
387 GetParentMeasure().SignalMove(*this); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
388 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
389 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
390 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
391 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
392 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
393 p1_ = p1_ + delta; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
394 p2_ = p2_ + delta; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
395 delta_ = ScenePoint2D(0, 0); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
396 GetParentMeasure().SignalMove(*this); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
397 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
398 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
399 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
400 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
401 class Circle : public Primitive |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
402 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
403 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
404 ScenePoint2D p1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
405 ScenePoint2D p2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
406 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
407 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
408 Circle(Measure& parentMeasure, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
409 const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
410 const ScenePoint2D& p2) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
411 Primitive(parentMeasure, 2), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
412 p1_(p1), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
413 p2_(p2) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
414 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
415 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
416 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
417 void SetPosition(const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
418 const ScenePoint2D& p2) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
419 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
420 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
421 p1_ = p1; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
422 p2_ = p2; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
423 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
424 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
425 ScenePoint2D GetPosition1() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
426 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
427 return p1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
428 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
429 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
430 ScenePoint2D GetPosition2() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
431 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
432 return p2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
433 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
434 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
435 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
436 const Scene2D& scene) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
437 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
438 return false; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
439 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
440 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
441 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
442 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
443 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
444 static unsigned int NUM_SEGMENTS = 128; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
445 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
446 ScenePoint2D middle((p1_.GetX() + p2_.GetX()) / 2.0, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
447 (p1_.GetY() + p2_.GetY()) / 2.0); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
448 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
449 const double radius = ScenePoint2D::DistancePtPt(middle, p1_); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
450 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
451 double increment = 2.0 * PI / static_cast<double>(NUM_SEGMENTS - 1); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
452 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
453 PolylineSceneLayer::Chain chain; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
454 chain.reserve(NUM_SEGMENTS); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
455 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
456 double theta = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
457 for (unsigned int i = 0; i < NUM_SEGMENTS; i++) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
458 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
459 chain.push_back(ScenePoint2D(middle.GetX() + radius * cos(theta), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
460 middle.GetY() + radius * sin(theta))); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
461 theta += increment; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
462 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
463 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
464 if (IsHover()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
465 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
466 polyline.AddChain(chain, false /* closed */, GetHoverColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
467 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
468 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
469 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
470 polyline.AddChain(chain, false /* closed */, GetColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
471 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
472 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
473 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
474 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
475 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
476 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
477 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
478 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
479 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
480 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
481 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
482 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
483 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
484 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
485 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
486 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
487 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
488 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
489 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
490 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
491 class Arc : public Primitive |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
492 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
493 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
494 ScenePoint2D start_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
495 ScenePoint2D middle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
496 ScenePoint2D end_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
497 double radius_; // in pixels |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
498 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
499 void ComputeAngles(double& fullAngle, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
500 double& startAngle, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
501 double& endAngle) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
502 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
503 const double x1 = start_.GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
504 const double y1 = start_.GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
505 const double xc = middle_.GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
506 const double yc = middle_.GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
507 const double x2 = end_.GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
508 const double y2 = end_.GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
509 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
510 startAngle = atan2(y1 - yc, x1 - xc); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
511 endAngle = atan2(y2 - yc, x2 - xc); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
512 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
513 fullAngle = endAngle - startAngle; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
514 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
515 while (fullAngle < -PI) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
516 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
517 fullAngle += 2.0 * PI; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
518 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
519 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
520 while (fullAngle >= PI) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
521 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
522 fullAngle -= 2.0 * PI; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
523 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
524 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
525 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
526 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
527 Arc(Measure& parentMeasure, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
528 const ScenePoint2D& start, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
529 const ScenePoint2D& middle, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
530 const ScenePoint2D& end) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
531 Primitive(parentMeasure, 2), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
532 start_(start), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
533 middle_(middle), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
534 end_(end), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
535 radius_(20) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
536 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
537 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
538 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
539 double GetAngle() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
540 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
541 double fullAngle, startAngle, endAngle; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
542 ComputeAngles(fullAngle, startAngle, endAngle); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
543 return fullAngle; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
544 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
545 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
546 void SetStart(const ScenePoint2D& p) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
547 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
548 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
549 start_ = p; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
550 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
551 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
552 void SetMiddle(const ScenePoint2D& p) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
553 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
554 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
555 middle_ = p; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
556 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
557 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
558 void SetEnd(const ScenePoint2D& p) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
559 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
560 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
561 end_ = p; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
562 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
563 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
564 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
565 const Scene2D& scene) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
566 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
567 return false; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
568 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
569 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
570 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
571 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
572 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
573 static unsigned int NUM_SEGMENTS = 64; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
574 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
575 const double radius = radius_ / scene.GetSceneToCanvasTransform().ComputeZoom(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
576 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
577 double fullAngle, startAngle, endAngle; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
578 ComputeAngles(fullAngle, startAngle, endAngle); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
579 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
580 double increment = fullAngle / static_cast<double>(NUM_SEGMENTS - 1); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
581 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
582 PolylineSceneLayer::Chain chain; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
583 chain.reserve(NUM_SEGMENTS); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
584 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
585 double theta = startAngle; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
586 for (unsigned int i = 0; i < NUM_SEGMENTS; i++) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
587 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
588 chain.push_back(ScenePoint2D(middle_.GetX() + radius * cos(theta), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
589 middle_.GetY() + radius * sin(theta))); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
590 theta += increment; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
591 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
592 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
593 if (IsHover()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
594 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
595 polyline.AddChain(chain, false /* closed */, GetHoverColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
596 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
597 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
598 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
599 polyline.AddChain(chain, false /* closed */, GetColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
600 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
601 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
602 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
603 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
604 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
605 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
606 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
607 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
608 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
609 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
610 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
611 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
612 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
613 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
614 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
615 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
616 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
617 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
618 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
619 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
620 class Text : public Primitive |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
621 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
622 private: |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
623 AnnotationsOverlay& that_; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
624 bool first_; |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
625 size_t subLayer_; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
626 std::unique_ptr<TextSceneLayer> content_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
627 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
628 public: |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
629 Text(AnnotationsOverlay& that, |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
630 Measure& parentMeasure) : |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
631 Primitive(parentMeasure, 2), |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
632 that_(that), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
633 first_(true) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
634 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
635 } |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
636 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
637 virtual ~Text() |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
638 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
639 if (content_.get() != NULL) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
640 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
641 that_.TagSubLayerToRemove(subLayer_); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
642 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
643 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
644 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
645 void SetContent(const TextSceneLayer& content) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
646 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
647 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
648 content_.reset(dynamic_cast<TextSceneLayer*>(content.Clone())); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
649 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
650 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
651 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
652 const Scene2D& scene) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
653 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
654 return false; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
655 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
656 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
657 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
658 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
659 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
660 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
661 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
662 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
663 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
664 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
665 if (content_.get() != NULL) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
666 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
667 std::unique_ptr<TextSceneLayer> layer(reinterpret_cast<TextSceneLayer*>(content_->Clone())); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
668 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
669 layer->SetColor(IsHover() ? GetHoverColor() : GetColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
670 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
671 if (first_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
672 { |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
673 subLayer_ = macro.AddLayer(layer.release()); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
674 first_ = false; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
675 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
676 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
677 { |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
678 macro.UpdateLayer(subLayer_, layer.release()); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
679 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
680 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
681 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
682 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
683 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
684 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
685 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
686 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
687 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
688 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
689 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
690 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
691 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
692 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
693 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
694 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
695 class EditPrimitiveTracker : public IFlexiblePointerTracker |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
696 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
697 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
698 Primitive& primitive_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
699 ScenePoint2D sceneClick_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
700 AffineTransform2D canvasToScene_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
701 bool alive_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
702 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
703 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
704 EditPrimitiveTracker(Primitive& primitive, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
705 const ScenePoint2D& sceneClick, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
706 const AffineTransform2D& canvasToScene) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
707 primitive_(primitive), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
708 sceneClick_(sceneClick), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
709 canvasToScene_(canvasToScene), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
710 alive_(true) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
711 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
712 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
713 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
714 virtual void PointerMove(const PointerEvent& event) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
715 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
716 primitive_.MovePreview(event.GetMainPosition().Apply(canvasToScene_) - sceneClick_); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
717 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
718 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
719 virtual void PointerUp(const PointerEvent& event) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
720 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
721 primitive_.MoveDone(event.GetMainPosition().Apply(canvasToScene_) - sceneClick_); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
722 alive_ = false; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
723 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
724 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
725 virtual void PointerDown(const PointerEvent& event) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
726 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
727 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
728 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
729 virtual bool IsAlive() const ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
730 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
731 return alive_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
732 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
733 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
734 virtual void Cancel() ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
735 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
736 primitive_.MoveDone(ScenePoint2D(0, 0)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
737 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
738 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
739 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
740 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
741 class SegmentMeasure : public Measure |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
742 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
743 private: |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
744 bool showLabel_; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
745 Handle& handle1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
746 Handle& handle2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
747 Segment& segment_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
748 Text& label_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
749 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
750 void UpdateLabel() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
751 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
752 if (showLabel_) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
753 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
754 TextSceneLayer content; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
755 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
756 double x1 = handle1_.GetCenter().GetX(); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
757 double y1 = handle1_.GetCenter().GetY(); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
758 double x2 = handle2_.GetCenter().GetX(); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
759 double y2 = handle2_.GetCenter().GetY(); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
760 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
761 // Put the label to the right of the right-most handle |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
762 if (x1 < x2) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
763 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
764 content.SetPosition(x2, y2); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
765 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
766 else |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
767 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
768 content.SetPosition(x1, y1); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
769 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
770 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
771 content.SetAnchor(BitmapAnchor_CenterLeft); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
772 content.SetBorder(10); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
773 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
774 double dx = x1 - x2; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
775 double dy = y1 - y2; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
776 char buf[32]; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
777 sprintf(buf, "%0.2f cm", sqrt(dx * dx + dy * dy) / 10.0); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
778 content.SetText(buf); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
779 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
780 label_.SetContent(content); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
781 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
782 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
783 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
784 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
785 SegmentMeasure(AnnotationsOverlay& that, |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
786 bool showLabel, |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
787 const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
788 const ScenePoint2D& p2) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
789 Measure(that), |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
790 showLabel_(showLabel), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
791 handle1_(AddTypedPrimitive<Handle>(new Handle(*this, p1))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
792 handle2_(AddTypedPrimitive<Handle>(new Handle(*this, p2))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
793 segment_(AddTypedPrimitive<Segment>(new Segment(*this, p1, p2))), |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
794 label_(AddTypedPrimitive<Text>(new Text(that, *this))) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
795 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
796 label_.SetColor(Color(255, 0, 0)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
797 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
798 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
799 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
800 Handle& GetHandle1() const |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
801 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
802 return handle1_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
803 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
804 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
805 Handle& GetHandle2() const |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
806 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
807 return handle2_; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
808 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
809 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
810 virtual void SignalMove(Primitive& primitive) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
811 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
812 if (&primitive == &handle1_ || |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
813 &primitive == &handle2_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
814 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
815 segment_.SetPosition(handle1_.GetCenter(), handle2_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
816 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
817 else if (&primitive == &segment_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
818 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
819 handle1_.SetCenter(segment_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
820 handle2_.SetCenter(segment_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
821 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
822 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
823 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
824 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
825 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
826 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
827 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
828 class AngleMeasure : public Measure |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
829 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
830 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
831 Handle& startHandle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
832 Handle& middleHandle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
833 Handle& endHandle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
834 Segment& segment1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
835 Segment& segment2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
836 Arc& arc_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
837 Text& label_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
838 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
839 void UpdateLabel() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
840 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
841 TextSceneLayer content; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
842 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
843 const double x1 = startHandle_.GetCenter().GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
844 const double x2 = middleHandle_.GetCenter().GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
845 const double y2 = middleHandle_.GetCenter().GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
846 const double x3 = endHandle_.GetCenter().GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
847 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
848 if (x2 < x1 && |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
849 x2 < x3) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
850 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
851 content.SetAnchor(BitmapAnchor_CenterRight); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
852 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
853 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
854 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
855 content.SetAnchor(BitmapAnchor_CenterLeft); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
856 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
857 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
858 content.SetPosition(x2, y2); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
859 content.SetBorder(10); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
860 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
861 char buf[32]; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
862 sprintf(buf, "%.01f%c%c", std::abs(arc_.GetAngle()) / PI * 180.0, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
863 0xc2, 0xb0 /* two bytes corresponding to degree symbol in UTF-8 */); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
864 content.SetText(buf); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
865 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
866 label_.SetContent(content); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
867 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
868 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
869 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
870 AngleMeasure(AnnotationsOverlay& that, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
871 const ScenePoint2D& start, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
872 const ScenePoint2D& middle, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
873 const ScenePoint2D& end) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
874 Measure(that), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
875 startHandle_(AddTypedPrimitive<Handle>(new Handle(*this, start))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
876 middleHandle_(AddTypedPrimitive<Handle>(new Handle(*this, middle))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
877 endHandle_(AddTypedPrimitive<Handle>(new Handle(*this, end))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
878 segment1_(AddTypedPrimitive<Segment>(new Segment(*this, start, middle))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
879 segment2_(AddTypedPrimitive<Segment>(new Segment(*this, middle, end))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
880 arc_(AddTypedPrimitive<Arc>(new Arc(*this, start, middle, end))), |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
881 label_(AddTypedPrimitive<Text>(new Text(that, *this))) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
882 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
883 label_.SetColor(Color(255, 0, 0)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
884 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
885 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
886 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
887 Handle& GetEndHandle() const |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
888 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
889 return endHandle_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
890 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
891 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
892 virtual void SignalMove(Primitive& primitive) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
893 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
894 if (&primitive == &startHandle_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
895 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
896 segment1_.SetPosition(startHandle_.GetCenter(), middleHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
897 arc_.SetStart(startHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
898 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
899 else if (&primitive == &middleHandle_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
900 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
901 segment1_.SetPosition(startHandle_.GetCenter(), middleHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
902 segment2_.SetPosition(middleHandle_.GetCenter(), endHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
903 arc_.SetMiddle(middleHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
904 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
905 else if (&primitive == &endHandle_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
906 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
907 segment2_.SetPosition(middleHandle_.GetCenter(), endHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
908 arc_.SetEnd(endHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
909 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
910 else if (&primitive == &segment1_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
911 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
912 startHandle_.SetCenter(segment1_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
913 middleHandle_.SetCenter(segment1_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
914 segment2_.SetPosition(segment1_.GetPosition2(), segment2_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
915 arc_.SetStart(segment1_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
916 arc_.SetMiddle(segment1_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
917 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
918 else if (&primitive == &segment2_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
919 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
920 middleHandle_.SetCenter(segment2_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
921 endHandle_.SetCenter(segment2_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
922 segment1_.SetPosition(segment1_.GetPosition1(), segment2_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
923 arc_.SetMiddle(segment2_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
924 arc_.SetEnd(segment2_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
925 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
926 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
927 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
928 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
929 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
930 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
931 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
932 class CircleMeasure : public Measure |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
933 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
934 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
935 Handle& handle1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
936 Handle& handle2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
937 Segment& segment_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
938 Circle& circle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
939 Text& label_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
940 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
941 void UpdateLabel() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
942 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
943 TextSceneLayer content; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
944 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
945 double x1 = handle1_.GetCenter().GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
946 double y1 = handle1_.GetCenter().GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
947 double x2 = handle2_.GetCenter().GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
948 double y2 = handle2_.GetCenter().GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
949 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
950 // Put the label to the right of the right-most handle |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
951 if (x1 < x2) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
952 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
953 content.SetPosition(x2, y2); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
954 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
955 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
956 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
957 content.SetPosition(x1, y1); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
958 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
959 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
960 content.SetAnchor(BitmapAnchor_CenterLeft); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
961 content.SetBorder(10); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
962 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
963 double dx = x1 - x2; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
964 double dy = y1 - y2; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
965 double diameter = sqrt(dx * dx + dy * dy); // in millimeters |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
966 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
967 double area = PI * diameter * diameter / 4.0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
968 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
969 char buf[32]; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
970 sprintf(buf, "%0.2f cm\n%0.2f cm%c%c", |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
971 diameter / 10.0, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
972 area / 100.0, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
973 0xc2, 0xb2 /* two bytes corresponding to two power in UTF-8 */); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
974 content.SetText(buf); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
975 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
976 label_.SetContent(content); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
977 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
978 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
979 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
980 CircleMeasure(AnnotationsOverlay& that, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
981 const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
982 const ScenePoint2D& p2) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
983 Measure(that), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
984 handle1_(AddTypedPrimitive<Handle>(new Handle(*this, p1))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
985 handle2_(AddTypedPrimitive<Handle>(new Handle(*this, p2))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
986 segment_(AddTypedPrimitive<Segment>(new Segment(*this, p1, p2))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
987 circle_(AddTypedPrimitive<Circle>(new Circle(*this, p1, p2))), |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
988 label_(AddTypedPrimitive<Text>(new Text(that, *this))) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
989 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
990 label_.SetColor(Color(255, 0, 0)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
991 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
992 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
993 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
994 Handle& GetHandle2() const |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
995 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
996 return handle2_; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
997 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
998 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
999 virtual void SignalMove(Primitive& primitive) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1000 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1001 if (&primitive == &handle1_ || |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1002 &primitive == &handle2_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1003 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1004 segment_.SetPosition(handle1_.GetCenter(), handle2_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1005 circle_.SetPosition(handle1_.GetCenter(), handle2_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1006 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1007 else if (&primitive == &segment_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1008 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1009 handle1_.SetCenter(segment_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1010 handle2_.SetCenter(segment_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1011 circle_.SetPosition(segment_.GetPosition1(), segment_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1012 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1013 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1014 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1015 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1016 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1017 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1018 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1019 class CreateSegmentOrCircleTracker : public IFlexiblePointerTracker |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1020 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1021 private: |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1022 AnnotationsOverlay& that_; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1023 Measure* measure_; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1024 AffineTransform2D canvasToScene_; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1025 Handle* handle2_; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1026 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1027 public: |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1028 CreateSegmentOrCircleTracker(AnnotationsOverlay& that, |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1029 bool isCircle, |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1030 const ScenePoint2D& sceneClick, |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1031 const AffineTransform2D& canvasToScene) : |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1032 that_(that), |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1033 measure_(NULL), |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1034 canvasToScene_(canvasToScene), |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1035 handle2_(NULL) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1036 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1037 if (isCircle) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1038 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1039 measure_ = new CircleMeasure(that, sceneClick, sceneClick); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1040 handle2_ = &dynamic_cast<CircleMeasure*>(measure_)->GetHandle2(); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1041 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1042 else |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1043 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1044 measure_ = new SegmentMeasure(that, true /* show label */, sceneClick, sceneClick); |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1045 handle2_ = &dynamic_cast<SegmentMeasure*>(measure_)->GetHandle2(); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1046 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1047 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1048 assert(measure_ != NULL && |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1049 handle2_ != NULL); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1050 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1051 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1052 virtual void PointerMove(const PointerEvent& event) ORTHANC_OVERRIDE |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1053 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1054 if (measure_ != NULL) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1055 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1056 assert(handle2_ != NULL); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1057 handle2_->SetCenter(event.GetMainPosition().Apply(canvasToScene_)); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1058 measure_->SignalMove(*handle2_); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1059 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1060 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1061 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1062 virtual void PointerUp(const PointerEvent& event) ORTHANC_OVERRIDE |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1063 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1064 measure_ = NULL; // IsAlive() becomes false |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1065 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1066 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1067 virtual void PointerDown(const PointerEvent& event) ORTHANC_OVERRIDE |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1068 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1069 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1070 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1071 virtual bool IsAlive() const ORTHANC_OVERRIDE |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1072 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1073 return (measure_ != NULL); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1074 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1075 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1076 virtual void Cancel() ORTHANC_OVERRIDE |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1077 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1078 if (measure_ != NULL) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1079 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1080 that_.DeleteMeasure(measure_); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1081 measure_ = NULL; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1082 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1083 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1084 }; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1085 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1086 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1087 class CreateAngleTracker : public IFlexiblePointerTracker |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1088 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1089 private: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1090 AnnotationsOverlay& that_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1091 SegmentMeasure* segment_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1092 AngleMeasure* angle_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1093 AffineTransform2D canvasToScene_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1094 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1095 public: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1096 CreateAngleTracker(AnnotationsOverlay& that, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1097 const ScenePoint2D& sceneClick, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1098 const AffineTransform2D& canvasToScene) : |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1099 that_(that), |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1100 segment_(NULL), |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1101 angle_(NULL), |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1102 canvasToScene_(canvasToScene) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1103 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1104 segment_ = new SegmentMeasure(that, false /* no length label */, sceneClick, sceneClick); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1105 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1106 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1107 virtual void PointerMove(const PointerEvent& event) ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1108 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1109 if (segment_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1110 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1111 segment_->GetHandle2().SetCenter(event.GetMainPosition().Apply(canvasToScene_)); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1112 segment_->SignalMove(segment_->GetHandle2()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1113 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1114 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1115 if (angle_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1116 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1117 angle_->GetEndHandle().SetCenter(event.GetMainPosition().Apply(canvasToScene_)); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1118 angle_->SignalMove(angle_->GetEndHandle()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1119 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1120 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1121 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1122 virtual void PointerUp(const PointerEvent& event) ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1123 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1124 if (segment_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1125 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1126 // End of first step: The first segment is available, now create the angle |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1127 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1128 angle_ = new AngleMeasure(that_, segment_->GetHandle1().GetCenter(), |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1129 segment_->GetHandle2().GetCenter(), |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1130 segment_->GetHandle2().GetCenter()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1131 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1132 that_.DeleteMeasure(segment_); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1133 segment_ = NULL; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1134 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1135 else |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1136 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1137 angle_ = NULL; // IsAlive() becomes false |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1138 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1139 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1140 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1141 virtual void PointerDown(const PointerEvent& event) ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1142 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1143 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1144 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1145 virtual bool IsAlive() const ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1146 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1147 return (segment_ != NULL || |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1148 angle_ != NULL); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1149 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1150 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1151 virtual void Cancel() ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1152 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1153 if (segment_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1154 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1155 that_.DeleteMeasure(segment_); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1156 segment_ = NULL; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1157 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1158 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1159 if (angle_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1160 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1161 that_.DeleteMeasure(angle_); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1162 angle_ = NULL; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1163 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1164 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1165 }; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1166 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1167 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1168 // Dummy tracker that is only used for deletion, in order to warn |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1169 // the caller that the mouse action was taken into consideration |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1170 class EraseTracker : public IFlexiblePointerTracker |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1171 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1172 public: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1173 EraseTracker() |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1174 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1175 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1176 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1177 virtual void PointerMove(const PointerEvent& event) ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1178 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1179 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1180 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1181 virtual void PointerUp(const PointerEvent& event) ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1182 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1183 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1184 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1185 virtual void PointerDown(const PointerEvent& event) ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1186 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1187 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1188 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1189 virtual bool IsAlive() const ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1190 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1191 return false; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1192 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1193 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1194 virtual void Cancel() ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1195 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1196 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1197 }; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1198 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1199 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1200 typedef std::set<Primitive*> Primitives; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1201 typedef std::set<Measure*> Measures; |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1202 typedef std::set<size_t> SubLayers; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1203 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1204 Tool activeTool_; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1205 size_t macroLayerIndex_; |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1206 size_t polylineSubLayer_; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1207 Primitives primitives_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1208 Measures measures_; |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1209 SubLayers subLayersToRemove_; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1210 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1211 void AddMeasure(Measure* measure) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1212 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1213 assert(measure != NULL); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1214 assert(measures_.find(measure) == measures_.end()); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1215 measures_.insert(measure); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1216 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1217 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1218 void DeleteMeasure(Measure* measure) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1219 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1220 if (measure != NULL) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1221 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1222 assert(measures_.find(measure) != measures_.end()); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1223 measures_.erase(measure); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1224 delete measure; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1225 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1226 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1227 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1228 void DeletePrimitive(Primitive* primitive) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1229 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1230 if (primitive != NULL) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1231 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1232 assert(primitives_.find(primitive) != primitives_.end()); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1233 primitives_.erase(primitive); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1234 delete primitive; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1235 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1236 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1237 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1238 void TagSubLayerToRemove(size_t subLayerIndex) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1239 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1240 assert(subLayersToRemove_.find(subLayerIndex) == subLayersToRemove_.end()); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1241 subLayersToRemove_.insert(subLayerIndex); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1242 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1243 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1244 public: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1245 AnnotationsOverlay(size_t macroLayerIndex) : |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1246 activeTool_(Tool_Edit), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1247 macroLayerIndex_(macroLayerIndex), |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1248 polylineSubLayer_(0) // dummy initialization |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1249 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1250 measures_.insert(new SegmentMeasure(*this, true /* show label */, ScenePoint2D(0, 0), ScenePoint2D(100, 100))); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1251 measures_.insert(new AngleMeasure(*this, ScenePoint2D(100, 50), ScenePoint2D(150, 40), ScenePoint2D(200, 50))); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1252 measures_.insert(new CircleMeasure(*this, ScenePoint2D(50, 200), ScenePoint2D(100, 250))); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1253 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1254 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1255 ~AnnotationsOverlay() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1256 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1257 for (Measures::iterator it = measures_.begin(); it != measures_.end(); ++it) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1258 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1259 assert(*it != NULL); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1260 delete *it; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1261 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1262 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1263 measures_.clear(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1264 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1265 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1266 void SetActiveTool(Tool tool) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1267 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1268 activeTool_ = tool; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1269 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1270 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1271 Tool GetActiveTool() const |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1272 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1273 return activeTool_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1274 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1275 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1276 void Render(Scene2D& scene) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1277 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1278 MacroSceneLayer* macro = NULL; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1279 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1280 if (scene.HasLayer(macroLayerIndex_)) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1281 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1282 macro = &dynamic_cast<MacroSceneLayer&>(scene.GetLayer(macroLayerIndex_)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1283 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1284 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1285 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1286 macro = &dynamic_cast<MacroSceneLayer&>(scene.SetLayer(macroLayerIndex_, new MacroSceneLayer)); |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1287 polylineSubLayer_ = macro->AddLayer(new PolylineSceneLayer); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1288 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1289 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1290 for (SubLayers::const_iterator it = subLayersToRemove_.begin(); it != subLayersToRemove_.end(); ++it) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1291 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1292 assert(macro->HasLayer(*it)); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1293 macro->DeleteLayer(*it); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1294 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1295 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1296 subLayersToRemove_.clear(); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1297 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1298 std::unique_ptr<PolylineSceneLayer> polyline(new PolylineSceneLayer); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1299 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1300 for (Primitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1301 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1302 assert(*it != NULL); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1303 Primitive& primitive = **it; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1304 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1305 primitive.RenderPolylineLayer(*polyline, scene); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1306 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1307 if (primitive.IsModified()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1308 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1309 primitive.RenderOtherLayers(*macro, scene); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1310 primitive.SetModified(false); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1311 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1312 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1313 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1314 macro->UpdateLayer(polylineSubLayer_, polyline.release()); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1315 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1316 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1317 bool ClearHover() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1318 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1319 bool needsRefresh = false; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1320 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1321 for (Primitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1322 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1323 assert(*it != NULL); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1324 if ((*it)->IsHover()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1325 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1326 (*it)->SetHover(false); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1327 needsRefresh = true; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1328 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1329 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1330 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1331 return needsRefresh; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1332 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1333 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1334 bool SetMouseHover(const ScenePoint2D& p /* expressed in canvas coordinates */, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1335 const Scene2D& scene) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1336 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1337 if (activeTool_ == Tool_None) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1338 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1339 return ClearHover(); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1340 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1341 else |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1342 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1343 bool needsRefresh = false; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1344 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1345 const ScenePoint2D s = p.Apply(scene.GetCanvasToSceneTransform()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1346 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1347 for (Primitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1348 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1349 assert(*it != NULL); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1350 bool hover = (*it)->IsHit(s, scene); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1351 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1352 if ((*it)->IsHover() != hover) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1353 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1354 needsRefresh = true; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1355 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1356 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1357 (*it)->SetHover(hover); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1358 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1359 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1360 return needsRefresh; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1361 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1362 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1363 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1364 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1365 IFlexiblePointerTracker* CreateTracker(const ScenePoint2D& p /* expressed in canvas coordinates */, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1366 const Scene2D& scene) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1367 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1368 if (activeTool_ == Tool_None) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1369 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1370 return NULL; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1371 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1372 else |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1373 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1374 const ScenePoint2D s = p.Apply(scene.GetCanvasToSceneTransform()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1375 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1376 Primitive* bestHit = NULL; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1377 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1378 for (Primitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1379 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1380 assert(*it != NULL); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1381 if ((*it)->IsHit(s, scene)) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1382 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1383 if (bestHit == NULL || |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1384 bestHit->GetDepth() > (*it)->GetDepth()) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1385 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1386 bestHit = *it; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1387 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1388 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1389 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1390 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1391 if (bestHit != NULL) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1392 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1393 if (activeTool_ == Tool_Erase) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1394 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1395 DeleteMeasure(&bestHit->GetParentMeasure()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1396 return new EraseTracker; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1397 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1398 else |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1399 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1400 return new EditPrimitiveTracker(*bestHit, s, scene.GetCanvasToSceneTransform()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1401 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1402 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1403 else |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1404 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1405 switch (activeTool_) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1406 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1407 case Tool_Segment: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1408 return new CreateSegmentOrCircleTracker(*this, false /* segment */, s, scene.GetCanvasToSceneTransform()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1409 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1410 case Tool_Circle: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1411 return new CreateSegmentOrCircleTracker(*this, true /* circle */, s, scene.GetCanvasToSceneTransform()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1412 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1413 case Tool_Angle: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1414 return new CreateAngleTracker(*this, s, scene.GetCanvasToSceneTransform()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1415 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1416 default: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1417 return NULL; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1418 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1419 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1420 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1421 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1422 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1423 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1424 #endif |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1425 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1426 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1427 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1428 std::string orthancUrl; |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1429 std::string instanceId; |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1430 int frameIndex = 0; |
1368 | 1431 |
1387
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
1432 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1433 static void ProcessOptions(int argc, char* argv[]) |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1434 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1435 namespace po = boost::program_options; |
1532
c7a37c3a0b8e
print help in sdl samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1512
diff
changeset
|
1436 po::options_description desc("Usage"); |
1368 | 1437 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1438 desc.add_options() |
1387
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
1439 ("loglevel", po::value<std::string>()->default_value("WARNING"), |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1440 "You can choose WARNING, INFO or TRACE for the logging level: Errors and warnings will always be displayed. (default: WARNING)") |
1368 | 1441 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1442 ("orthanc", po::value<std::string>()->default_value("http://localhost:8042"), |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1443 "Base URL of the Orthanc instance") |
1368 | 1444 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1445 ("instance", po::value<std::string>()->default_value("285dece8-e1956b38-cdc7d084-6ce3371e-536a9ffc"), |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1446 "Orthanc ID of the instance to display") |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1447 |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1448 ("frame_index", po::value<int>()->default_value(0), |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1449 "The zero-based index of the frame (for multi-frame instances)") |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1450 ; |
1368 | 1451 |
1532
c7a37c3a0b8e
print help in sdl samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1512
diff
changeset
|
1452 std::cout << desc << std::endl; |
c7a37c3a0b8e
print help in sdl samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1512
diff
changeset
|
1453 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1454 std::cout << std::endl << "Keyboard shorcuts:" << std::endl |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1455 << " a\tEnable/disable the angle measure tool" << std::endl |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1456 << " f\tToggle fullscreen display" << std::endl |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1457 << " l\tEnable/disable the line measure tool" << std::endl |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1458 << " q\tExit" << std::endl |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1459 << " r\tRedo the last edit to the measure tools" << std::endl |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1460 << " s\tFit the viewpoint to the image" << std::endl |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1461 << " u\tUndo the last edit to the measure tools" << std::endl |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1462 << std::endl << "Mouse buttons:" << std::endl |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1463 << " left \tChange windowing, or edit measure" << std::endl |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1464 << " center\tMove the viewpoint, or edit measure" << std::endl |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1465 << " right \tZoom, or edit measure" << std::endl |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1466 << std::endl; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1467 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1468 po::variables_map vm; |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1469 try |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1470 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1471 po::store(po::parse_command_line(argc, argv, desc), vm); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1472 po::notify(vm); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1473 } |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1474 catch (std::exception& e) |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1475 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1476 std::cerr << "Please check your command line options! (\"" << e.what() << "\")" << std::endl; |
1368 | 1477 } |
1478 | |
1387
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
1479 if (vm.count("loglevel") > 0) |
1368 | 1480 { |
1387
4ebf246f3919
Fixed big mistake (factoring the option parsing, which only adds noise to the people reading the code)
Benjamin Golinvaux <bgo@osimis.io>
parents:
1383
diff
changeset
|
1481 std::string logLevel = vm["loglevel"].as<std::string>(); |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1482 OrthancStoneHelpers::SetLogLevel(logLevel); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1483 } |
1368 | 1484 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1485 if (vm.count("orthanc") > 0) |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1486 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1487 // maybe check URL validity here |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1488 orthancUrl = vm["orthanc"].as<std::string>(); |
1368 | 1489 } |
1490 | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1491 if (vm.count("instance") > 0) |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1492 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1493 instanceId = vm["instance"].as<std::string>(); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1494 } |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1495 |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1496 if (vm.count("frame_index") > 0) |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1497 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1498 frameIndex = vm["frame_index"].as<int>(); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1499 } |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1500 } |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1501 |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1502 |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1503 enum ActiveTool |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1504 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1505 ActiveTool_None, |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1506 ActiveTool_Line, |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1507 ActiveTool_Angle |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1508 }; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1509 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1510 |
1368 | 1511 /** |
1512 * IMPORTANT: The full arguments to "main()" are needed for SDL on | |
1513 * Windows. Otherwise, one gets the linking error "undefined reference | |
1514 * to `SDL_main'". https://wiki.libsdl.org/FAQWindows | |
1515 **/ | |
1516 int main(int argc, char* argv[]) | |
1517 { | |
1518 try | |
1519 { | |
1520 OrthancStone::StoneInitialize(); | |
1591
5887a4f8594b
moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1576
diff
changeset
|
1521 OrthancStone::SdlWindow::GlobalInitialize(); |
5887a4f8594b
moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1576
diff
changeset
|
1522 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1523 ProcessOptions(argc, argv); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1524 |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1525 //Orthanc::Logging::EnableInfoLevel(true); |
1368 | 1526 //Orthanc::Logging::EnableTraceLevel(true); |
1527 | |
1528 { | |
1529 | |
1530 #if 1 | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1531 boost::shared_ptr<OrthancStone::SdlViewport> viewport = |
1368 | 1532 OrthancStone::SdlOpenGLViewport::Create("Stone of Orthanc", 800, 600); |
1533 #else | |
1534 boost::shared_ptr<OrthancStone::SdlViewport> viewport = | |
1535 OrthancStone::SdlCairoViewport::Create("Stone of Orthanc", 800, 600); | |
1536 #endif | |
1537 | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1538 boost::shared_ptr<OrthancStone::UndoStack> undoStack(new OrthancStone::UndoStack); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1539 |
1368 | 1540 OrthancStone::GenericLoadersContext context(1, 4, 1); |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1541 |
1395
62dc0d737e7b
build script for wasm sample + updated instructions + fixed Sdl sample for Orthanc listening on other ports that 8042
Alain Mazy <alain@mazy.be>
parents:
1392
diff
changeset
|
1542 Orthanc::WebServiceParameters orthancWebService; |
62dc0d737e7b
build script for wasm sample + updated instructions + fixed Sdl sample for Orthanc listening on other ports that 8042
Alain Mazy <alain@mazy.be>
parents:
1392
diff
changeset
|
1543 orthancWebService.SetUrl(orthancUrl); |
62dc0d737e7b
build script for wasm sample + updated instructions + fixed Sdl sample for Orthanc listening on other ports that 8042
Alain Mazy <alain@mazy.be>
parents:
1392
diff
changeset
|
1544 context.SetOrthancParameters(orthancWebService); |
62dc0d737e7b
build script for wasm sample + updated instructions + fixed Sdl sample for Orthanc listening on other ports that 8042
Alain Mazy <alain@mazy.be>
parents:
1392
diff
changeset
|
1545 |
1368 | 1546 context.StartOracle(); |
1547 | |
1548 { | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1549 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1550 std::string font; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1551 Orthanc::EmbeddedResources::GetFileResource(font, Orthanc::EmbeddedResources::UBUNTU_FONT); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1552 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1553 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1554 lock->GetCompositor().SetFont(0, font, 16, Orthanc::Encoding_Latin1); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1555 lock->GetController().SetUndoStack(undoStack); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1556 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1557 |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1558 ActiveTool activeTool = ActiveTool_None; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1559 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1560 boost::shared_ptr<OrthancStone::LineMeasureTool> lineMeasureTool(OrthancStone::LineMeasureTool::Create(viewport)); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1561 bool lineMeasureFirst = true; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1562 lineMeasureTool->Disable(); |
1368 | 1563 |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1564 boost::shared_ptr<OrthancStone::AngleMeasureTool> angleMeasureTool(OrthancStone::AngleMeasureTool::Create(viewport)); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1565 bool angleMeasureFirst = true; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1566 angleMeasureTool->Disable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1567 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1568 OrthancStone::AnnotationsOverlay overlay(10); |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1569 overlay.SetActiveTool(OrthancStone::AnnotationsOverlay::Tool_Angle); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1570 |
1368 | 1571 boost::shared_ptr<SdlSimpleViewerApplication> application( |
1572 SdlSimpleViewerApplication::Create(context, viewport)); | |
1573 | |
1574 OrthancStone::DicomSource source; | |
1575 | |
1576 application->LoadOrthancFrame(source, instanceId, frameIndex); | |
1577 | |
1578 OrthancStone::DefaultViewportInteractor interactor; | |
1535
301571299212
DefaultViewportInteractor::SetWindowingLayer()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1532
diff
changeset
|
1579 interactor.SetWindowingLayer(0); |
1368 | 1580 |
1581 { | |
1582 int scancodeCount = 0; | |
1583 const uint8_t* keyboardState = SDL_GetKeyboardState(&scancodeCount); | |
1584 | |
1585 bool stop = false; | |
1586 while (!stop) | |
1587 { | |
1588 bool paint = false; | |
1589 SDL_Event event; | |
1590 while (SDL_PollEvent(&event)) | |
1591 { | |
1592 if (event.type == SDL_QUIT) | |
1593 { | |
1594 stop = true; | |
1595 break; | |
1596 } | |
1597 else if (viewport->IsRefreshEvent(event)) | |
1598 { | |
1599 paint = true; | |
1600 } | |
1601 else if (event.type == SDL_WINDOWEVENT && | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1602 (event.window.event == SDL_WINDOWEVENT_RESIZED || |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1603 event.window.event == SDL_WINDOWEVENT_SIZE_CHANGED)) |
1368 | 1604 { |
1605 viewport->UpdateSize(event.window.data1, event.window.data2); | |
1606 } | |
1607 else if (event.type == SDL_WINDOWEVENT && | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1608 (event.window.event == SDL_WINDOWEVENT_SHOWN || |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1609 event.window.event == SDL_WINDOWEVENT_EXPOSED)) |
1368 | 1610 { |
1576
92fca2b3ba3d
sanitizing the handling of canvas size
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1560
diff
changeset
|
1611 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
92fca2b3ba3d
sanitizing the handling of canvas size
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1560
diff
changeset
|
1612 lock->RefreshCanvasSize(); |
1368 | 1613 } |
1614 else if (event.type == SDL_KEYDOWN && | |
1615 event.key.repeat == 0 /* Ignore key bounce */) | |
1616 { | |
1617 switch (event.key.keysym.sym) | |
1618 { | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1619 case SDLK_f: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1620 viewport->ToggleMaximize(); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1621 break; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1622 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1623 case SDLK_s: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1624 application->FitContent(); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1625 break; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1626 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1627 case SDLK_q: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1628 stop = true; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1629 break; |
1368 | 1630 |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1631 case SDLK_u: |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1632 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1633 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1634 if (lock->GetController().CanUndo()) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1635 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1636 lock->GetController().Undo(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1637 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1638 break; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1639 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1640 |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1641 case SDLK_r: |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1642 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1643 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1644 if (lock->GetController().CanRedo()) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1645 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1646 lock->GetController().Redo(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1647 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1648 break; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1649 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1650 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1651 case SDLK_l: |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1652 if (activeTool == ActiveTool_Line) |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1653 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1654 lineMeasureTool->Disable(); |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1655 activeTool = ActiveTool_None; |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1656 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1657 else |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1658 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1659 if (lineMeasureFirst) |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1660 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1661 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1662 OrthancStone::Extent2D extent; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1663 lock->GetController().GetScene().GetBoundingBox(extent); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1664 if (!extent.IsEmpty()) |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1665 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1666 OrthancStone::ScenePoint2D p(extent.GetCenterX(), extent.GetCenterY()); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1667 lineMeasureTool->Set(p, p); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1668 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1669 lineMeasureFirst = false; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1670 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1671 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1672 lineMeasureTool->Enable(); |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1673 angleMeasureTool->Disable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1674 activeTool = ActiveTool_Line; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1675 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1676 break; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1677 |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1678 case SDLK_a: |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1679 if (activeTool == ActiveTool_Angle) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1680 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1681 angleMeasureTool->Disable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1682 activeTool = ActiveTool_None; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1683 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1684 else |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1685 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1686 if (angleMeasureFirst) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1687 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1688 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1689 OrthancStone::Extent2D extent; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1690 lock->GetController().GetScene().GetBoundingBox(extent); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1691 if (!extent.IsEmpty()) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1692 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1693 OrthancStone::ScenePoint2D p1(1.0 * extent.GetX1() / 3.0 + 2.0 * extent.GetX2() / 3.0, |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1694 2.0 * extent.GetY1() / 3.0 + 2.0 * extent.GetY2() / 3.0); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1695 OrthancStone::ScenePoint2D p2(1.0 * extent.GetX1() / 2.0 + 1.0 * extent.GetX2() / 2.0, |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1696 1.0 * extent.GetY1() / 3.0 + 1.0 * extent.GetY2() / 3.0); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1697 OrthancStone::ScenePoint2D p3(2.0 * extent.GetX1() / 3.0 + 1.0 * extent.GetX2() / 3.0, |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1698 2.0 * extent.GetY1() / 3.0 + 2.0 * extent.GetY2() / 3.0); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1699 angleMeasureTool->SetSide1End(p1); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1700 angleMeasureTool->SetCenter(p2); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1701 angleMeasureTool->SetSide2End(p3); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1702 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1703 angleMeasureFirst = false; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1704 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1705 |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1706 lineMeasureTool->Disable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1707 angleMeasureTool->Enable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1708 activeTool = ActiveTool_Angle; |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1709 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1710 break; |
1368 | 1711 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1712 default: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1713 break; |
1368 | 1714 } |
1715 } | |
1716 else if (event.type == SDL_MOUSEBUTTONDOWN || | |
1717 event.type == SDL_MOUSEMOTION || | |
1718 event.type == SDL_MOUSEBUTTONUP) | |
1719 { | |
1507
169adf9090a6
replacing deprecated std::auto_ptr by std::unique_ptr
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1458
diff
changeset
|
1720 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
1368 | 1721 if (lock->HasCompositor()) |
1722 { | |
1723 OrthancStone::PointerEvent p; | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1724 OrthancStoneHelpers::GetPointerEvent(p, lock->GetCompositor(), |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1725 event, keyboardState, scancodeCount); |
1368 | 1726 |
1727 switch (event.type) | |
1728 { | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1729 case SDL_MOUSEBUTTONDOWN: |
1368 | 1730 { |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1731 boost::shared_ptr<OrthancStone::IFlexiblePointerTracker> t; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1732 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1733 t.reset(overlay.CreateTracker(p.GetMainPosition(), lock->GetController().GetScene())); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1734 if (t.get() == NULL) |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1735 { |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1736 switch (activeTool) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1737 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1738 case ActiveTool_Angle: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1739 t = angleMeasureTool->CreateEditionTracker(p); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1740 break; |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1741 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1742 case ActiveTool_Line: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1743 t = lineMeasureTool->CreateEditionTracker(p); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1744 break; |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1745 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1746 case ActiveTool_None: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1747 break; |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1748 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1749 default: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1750 throw Orthanc::OrthancException(Orthanc::ErrorCode_NotImplemented); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1751 } |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1752 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1753 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1754 if (t.get() != NULL) |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1755 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1756 lock->GetController().AcquireActiveTracker(t); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1757 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1758 else |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1759 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1760 lock->GetController().HandleMousePress(interactor, p, |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1761 lock->GetCompositor().GetCanvasWidth(), |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1762 lock->GetCompositor().GetCanvasHeight()); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1763 } |
1368 | 1764 lock->Invalidate(); |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1765 break; |
1368 | 1766 } |
1767 | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1768 case SDL_MOUSEMOTION: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1769 if (lock->GetController().HandleMouseMove(p)) |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1770 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1771 lock->Invalidate(); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1772 if (overlay.ClearHover()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1773 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1774 paint = true; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1775 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1776 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1777 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1778 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1779 if (overlay.SetMouseHover(p.GetMainPosition(), lock->GetController().GetScene())) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1780 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1781 paint = true; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1782 } |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1783 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1784 break; |
1368 | 1785 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1786 case SDL_MOUSEBUTTONUP: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1787 lock->GetController().HandleMouseRelease(p); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1788 lock->Invalidate(); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1789 break; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1790 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1791 default: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1792 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
1368 | 1793 } |
1794 } | |
1795 } | |
1796 } | |
1797 | |
1798 if (paint) | |
1799 { | |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1800 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1801 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1802 overlay.Render(lock->GetController().GetScene()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1803 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1804 |
1368 | 1805 viewport->Paint(); |
1806 } | |
1807 | |
1808 // Small delay to avoid using 100% of CPU | |
1809 SDL_Delay(1); | |
1810 } | |
1811 } | |
1812 context.StopOracle(); | |
1813 } | |
1814 } | |
1815 | |
1591
5887a4f8594b
moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1576
diff
changeset
|
1816 OrthancStone::SdlWindow::GlobalFinalize(); |
1368 | 1817 OrthancStone::StoneFinalize(); |
1818 return 0; | |
1819 } | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1820 catch (Orthanc::OrthancException& e) |
1368 | 1821 { |
1822 LOG(ERROR) << "OrthancException: " << e.What(); | |
1823 return -1; | |
1824 } | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1825 catch (OrthancStone::StoneException& e) |
1368 | 1826 { |
1827 LOG(ERROR) << "StoneException: " << e.What(); | |
1828 return -1; | |
1829 } | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1830 catch (std::runtime_error& e) |
1368 | 1831 { |
1832 LOG(ERROR) << "Runtime error: " << e.what(); | |
1833 return -1; | |
1834 } | |
1835 catch (...) | |
1836 { | |
1837 LOG(ERROR) << "Native exception"; | |
1838 return -1; | |
1839 } | |
1840 } |