Mercurial > hg > orthanc-stone
annotate Applications/Samples/Sdl/SingleFrameViewer/SdlSimpleViewer.cpp @ 1803:d1849468729b
added messages to AnnotationsLayer
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Thu, 20 May 2021 14:15:00 +0200 |
parents | 64dad1d7aca4 |
children | 5a872e69c74f |
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>(); |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
54 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
55 static const char* const KEY_ANNOTATIONS = "annotations"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
56 static const char* const KEY_TYPE = "type"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
57 static const char* const KEY_X1 = "x1"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
58 static const char* const KEY_Y1 = "y1"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
59 static const char* const KEY_X2 = "x2"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
60 static const char* const KEY_Y2 = "y2"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
61 static const char* const KEY_X3 = "x3"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
62 static const char* const KEY_Y3 = "y3"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
63 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
64 static const char* const VALUE_ANGLE = "angle"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
65 static const char* const VALUE_CIRCLE = "circle"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
66 static const char* const VALUE_SEGMENT = "segment"; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
67 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
68 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
69 namespace OrthancStone |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
70 { |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
71 class AnnotationsLayer : public IObservable |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
72 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
73 public: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
74 ORTHANC_STONE_DEFINE_ORIGIN_MESSAGE(__FILE__, __LINE__, AnnotationAddedMessage, AnnotationsLayer); |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
75 ORTHANC_STONE_DEFINE_ORIGIN_MESSAGE(__FILE__, __LINE__, AnnotationRemovedMessage, AnnotationsLayer); |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
76 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
77 enum Tool |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
78 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
79 Tool_Edit, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
80 Tool_None, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
81 Tool_Segment, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
82 Tool_Angle, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
83 Tool_Circle, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
84 Tool_Erase |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
85 }; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
86 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
87 private: |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
88 class Annotation; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
89 |
1801 | 90 class GeometricPrimitive : public boost::noncopyable |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
91 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
92 private: |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
93 bool modified_; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
94 Annotation& parentAnnotation_; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
95 Color color_; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
96 Color hoverColor_; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
97 bool isHover_; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
98 int depth_; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
99 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
100 public: |
1801 | 101 GeometricPrimitive(Annotation& parentAnnotation, |
102 int depth) : | |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
103 modified_(true), |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
104 parentAnnotation_(parentAnnotation), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
105 color_(192, 192, 192), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
106 hoverColor_(0, 255, 0), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
107 isHover_(false), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
108 depth_(depth) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
109 { |
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 |
1801 | 112 virtual ~GeometricPrimitive() |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
113 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
114 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
115 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
116 Annotation& GetParentAnnotation() const |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
117 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
118 return parentAnnotation_; |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
119 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
120 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
121 int GetDepth() const |
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 return depth_; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
126 void SetHover(bool hover) |
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 if (hover != isHover_) |
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 isHover_ = hover; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
131 modified_ = true; |
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 } |
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 bool IsHover() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
136 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
137 return isHover_; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
140 void SetModified(bool modified) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
141 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
142 modified_ = modified; |
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 bool IsModified() 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 modified_; |
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 void SetColor(const Color& color) |
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 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
153 color_ = color; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
156 void SetHoverColor(const Color& color) |
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 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
159 hoverColor_ = color; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
160 } |
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 const Color& GetColor() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
163 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
164 return color_; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
167 const Color& GetHoverColor() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
168 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
169 return hoverColor_; |
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 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
173 const Scene2D& scene) const = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
174 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
175 // Always called, even if not modified |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
176 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
177 const Scene2D& scene) = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
178 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
179 // Only called if modified |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
180 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
181 const Scene2D& scene) = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
182 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
183 virtual void MovePreview(const ScenePoint2D& delta) = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
184 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
185 virtual void MoveDone(const ScenePoint2D& delta) = 0; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
188 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
189 class Annotation : public boost::noncopyable |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
190 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
191 private: |
1801 | 192 typedef std::list<GeometricPrimitive*> GeometricPrimitives; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
193 |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
194 AnnotationsLayer& that_; |
1801 | 195 GeometricPrimitives primitives_; |
1796
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 public: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
198 Annotation(AnnotationsLayer& that) : |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
199 that_(that) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
200 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
201 that.AddAnnotation(this); |
1796
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 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
204 virtual ~Annotation() |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
205 { |
1801 | 206 for (GeometricPrimitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
207 { |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
208 that_.DeletePrimitive(*it); |
1796
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 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
211 |
1801 | 212 GeometricPrimitive* AddPrimitive(GeometricPrimitive* primitive) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
213 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
214 if (primitive == NULL) |
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 throw Orthanc::OrthancException(Orthanc::ErrorCode_NullPointer); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
217 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
218 else |
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 assert(that_.primitives_.find(primitive) == that_.primitives_.end()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
221 primitives_.push_back(primitive); // For automated deallocation |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
222 that_.primitives_.insert(primitive); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
223 return primitive; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
224 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
225 } |
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 template <typename T> |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
228 T& AddTypedPrimitive(T* primitive) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
229 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
230 AddPrimitive(primitive); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
231 return *primitive; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
232 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
233 |
1801 | 234 virtual void SignalMove(GeometricPrimitive& primitive) = 0; |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
235 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
236 virtual void Serialize(Json::Value& target) = 0; |
1796
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
239 |
1801 | 240 class Handle : public GeometricPrimitive |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
241 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
242 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
243 ScenePoint2D center_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
244 ScenePoint2D delta_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
245 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
246 public: |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
247 explicit Handle(Annotation& parentAnnotation, |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
248 const ScenePoint2D& center) : |
1801 | 249 GeometricPrimitive(parentAnnotation, 0), // Highest priority |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
250 center_(center), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
251 delta_(0, 0) |
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 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
254 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
255 void SetSize(unsigned int size) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
256 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
257 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
258 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
259 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
260 void SetCenter(const ScenePoint2D& center) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
261 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
262 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
263 center_ = center; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
264 delta_ = ScenePoint2D(0, 0); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
265 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
266 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
267 ScenePoint2D GetCenter() const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
268 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
269 return center_ + delta_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
270 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
271 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
272 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
273 const Scene2D& scene) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
274 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
275 const double zoom = scene.GetSceneToCanvasTransform().ComputeZoom(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
276 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
277 double dx = (center_.GetX() + delta_.GetX() - p.GetX()) * zoom; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
278 double dy = (center_.GetY() + delta_.GetY() - p.GetY()) * zoom; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
279 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
280 return (std::abs(dx) <= HANDLE_SIZE / 2.0 && |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
281 std::abs(dy) <= HANDLE_SIZE / 2.0); |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
284 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
285 const Scene2D& scene) ORTHANC_OVERRIDE |
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 const double zoom = scene.GetSceneToCanvasTransform().ComputeZoom(); |
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 // TODO: take DPI into account |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
290 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
|
291 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
|
292 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
|
293 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
|
294 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
295 PolylineSceneLayer::Chain chain; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
296 chain.reserve(4); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
297 chain.push_back(ScenePoint2D(x1, y1)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
298 chain.push_back(ScenePoint2D(x2, y1)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
299 chain.push_back(ScenePoint2D(x2, y2)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
300 chain.push_back(ScenePoint2D(x1, y2)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
301 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
302 if (IsHover()) |
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 polyline.AddChain(chain, true /* closed */, GetHoverColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
305 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
306 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
307 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
308 polyline.AddChain(chain, true /* closed */, GetColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
309 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
310 } |
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 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
313 const Scene2D& scene) ORTHANC_OVERRIDE |
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 } |
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 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
318 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
319 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
320 delta_ = delta; |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
321 GetParentAnnotation().SignalMove(*this); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
322 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
323 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
324 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
325 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
326 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
327 center_ = center_ + delta; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
328 delta_ = ScenePoint2D(0, 0); |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
329 GetParentAnnotation().SignalMove(*this); |
1796
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 |
1801 | 334 class Segment : public GeometricPrimitive |
1796
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 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
337 ScenePoint2D p1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
338 ScenePoint2D p2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
339 ScenePoint2D delta_; |
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 public: |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
342 Segment(Annotation& parentAnnotation, |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
343 const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
344 const ScenePoint2D& p2) : |
1801 | 345 GeometricPrimitive(parentAnnotation, 1), // Can only be selected if no handle matches |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
346 p1_(p1), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
347 p2_(p2), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
348 delta_(0, 0) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
349 { |
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 void SetPosition(const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
353 const ScenePoint2D& p2) |
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 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
356 p1_ = p1; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
357 p2_ = p2; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
358 delta_ = ScenePoint2D(0, 0); |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
361 ScenePoint2D GetPosition1() const |
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 return p1_ + delta_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
364 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
365 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
366 ScenePoint2D GetPosition2() const |
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 return p2_ + delta_; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
371 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
372 const Scene2D& scene) const |
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 const double zoom = scene.GetSceneToCanvasTransform().ComputeZoom(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
375 return (ScenePoint2D::SquaredDistancePtSegment(p1_ + delta_, p2_ + delta_, p) * zoom * zoom <= |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
376 (HANDLE_SIZE / 2.0) * (HANDLE_SIZE / 2.0)); |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
379 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
380 const Scene2D& scene) ORTHANC_OVERRIDE |
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 PolylineSceneLayer::Chain chain; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
383 chain.reserve(2); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
384 chain.push_back(p1_ + delta_); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
385 chain.push_back(p2_ + delta_); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
386 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
387 if (IsHover()) |
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 polyline.AddChain(chain, false /* closed */, GetHoverColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
390 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
391 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
392 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
393 polyline.AddChain(chain, false /* closed */, GetColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
394 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
395 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
396 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
397 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
398 const Scene2D& scene) ORTHANC_OVERRIDE |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
402 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
403 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
404 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
405 delta_ = delta; |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
406 GetParentAnnotation().SignalMove(*this); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
407 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
408 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
409 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
410 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
411 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
412 p1_ = p1_ + delta; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
413 p2_ = p2_ + delta; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
414 delta_ = ScenePoint2D(0, 0); |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
415 GetParentAnnotation().SignalMove(*this); |
1796
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 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
418 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
419 |
1801 | 420 class Circle : public GeometricPrimitive |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
421 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
422 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
423 ScenePoint2D p1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
424 ScenePoint2D p2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
425 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
426 public: |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
427 Circle(Annotation& parentAnnotation, |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
428 const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
429 const ScenePoint2D& p2) : |
1801 | 430 GeometricPrimitive(parentAnnotation, 2), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
431 p1_(p1), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
432 p2_(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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
436 void SetPosition(const ScenePoint2D& p1, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
437 const ScenePoint2D& p2) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
438 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
439 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
440 p1_ = p1; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
441 p2_ = p2; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
442 } |
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 ScenePoint2D GetPosition1() const |
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 return p1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
447 } |
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 ScenePoint2D GetPosition2() const |
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 return p2_; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
454 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
455 const Scene2D& scene) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
456 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
457 return false; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
460 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
461 const Scene2D& scene) ORTHANC_OVERRIDE |
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 static unsigned int NUM_SEGMENTS = 128; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
464 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
465 ScenePoint2D middle((p1_.GetX() + p2_.GetX()) / 2.0, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
466 (p1_.GetY() + p2_.GetY()) / 2.0); |
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 const double radius = ScenePoint2D::DistancePtPt(middle, p1_); |
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 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
|
471 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
472 PolylineSceneLayer::Chain chain; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
473 chain.reserve(NUM_SEGMENTS); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
474 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
475 double theta = 0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
476 for (unsigned int i = 0; i < NUM_SEGMENTS; i++) |
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 chain.push_back(ScenePoint2D(middle.GetX() + radius * cos(theta), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
479 middle.GetY() + radius * sin(theta))); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
480 theta += increment; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
481 } |
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 if (IsHover()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
484 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
485 polyline.AddChain(chain, false /* closed */, GetHoverColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
486 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
487 else |
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 polyline.AddChain(chain, false /* closed */, GetColor()); |
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 } |
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 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
494 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
495 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
496 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
497 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
498 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
499 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
500 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
501 } |
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 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
504 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
505 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
506 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
507 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
508 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
509 |
1801 | 510 class Arc : public GeometricPrimitive |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
511 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
512 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
513 ScenePoint2D start_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
514 ScenePoint2D middle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
515 ScenePoint2D end_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
516 double radius_; // in pixels |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
517 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
518 void ComputeAngles(double& fullAngle, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
519 double& startAngle, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
520 double& endAngle) const |
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 const double x1 = start_.GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
523 const double y1 = start_.GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
524 const double xc = middle_.GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
525 const double yc = middle_.GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
526 const double x2 = end_.GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
527 const double y2 = end_.GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
528 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
529 startAngle = atan2(y1 - yc, x1 - xc); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
530 endAngle = atan2(y2 - yc, x2 - xc); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
531 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
532 fullAngle = endAngle - startAngle; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
533 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
534 while (fullAngle < -PI) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
535 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
536 fullAngle += 2.0 * PI; |
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 while (fullAngle >= PI) |
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 fullAngle -= 2.0 * PI; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
542 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
543 } |
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 public: |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
546 Arc(Annotation& parentAnnotation, |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
547 const ScenePoint2D& start, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
548 const ScenePoint2D& middle, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
549 const ScenePoint2D& end) : |
1801 | 550 GeometricPrimitive(parentAnnotation, 2), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
551 start_(start), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
552 middle_(middle), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
553 end_(end), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
554 radius_(20) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
555 { |
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 double GetAngle() const |
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 double fullAngle, startAngle, endAngle; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
561 ComputeAngles(fullAngle, startAngle, endAngle); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
562 return fullAngle; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
565 void SetStart(const ScenePoint2D& p) |
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 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
568 start_ = p; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
571 void SetMiddle(const ScenePoint2D& p) |
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 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
574 middle_ = p; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
575 } |
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 void SetEnd(const ScenePoint2D& p) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
578 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
579 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
580 end_ = p; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
583 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
584 const Scene2D& scene) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
585 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
586 return false; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
589 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
590 const Scene2D& scene) ORTHANC_OVERRIDE |
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 static unsigned int NUM_SEGMENTS = 64; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
593 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
594 const double radius = radius_ / scene.GetSceneToCanvasTransform().ComputeZoom(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
595 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
596 double fullAngle, startAngle, endAngle; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
597 ComputeAngles(fullAngle, startAngle, endAngle); |
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 double increment = fullAngle / static_cast<double>(NUM_SEGMENTS - 1); |
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 PolylineSceneLayer::Chain chain; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
602 chain.reserve(NUM_SEGMENTS); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
603 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
604 double theta = startAngle; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
605 for (unsigned int i = 0; i < NUM_SEGMENTS; i++) |
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 chain.push_back(ScenePoint2D(middle_.GetX() + radius * cos(theta), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
608 middle_.GetY() + radius * sin(theta))); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
609 theta += increment; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
610 } |
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 if (IsHover()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
613 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
614 polyline.AddChain(chain, false /* closed */, GetHoverColor()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
615 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
616 else |
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 polyline.AddChain(chain, false /* closed */, GetColor()); |
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 } |
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 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
623 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
624 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
625 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
626 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
627 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
628 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
629 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
630 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
631 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
632 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
633 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
634 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
635 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
636 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
637 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
638 |
1801 | 639 class Text : public GeometricPrimitive |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
640 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
641 private: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
642 AnnotationsLayer& that_; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
643 bool first_; |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
644 size_t subLayer_; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
645 std::unique_ptr<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 public: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
648 Text(AnnotationsLayer& that, |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
649 Annotation& parentAnnotation) : |
1801 | 650 GeometricPrimitive(parentAnnotation, 2), |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
651 that_(that), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
652 first_(true) |
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 } |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
655 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
656 virtual ~Text() |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
657 { |
1800
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
658 if (!first_) |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
659 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
660 that_.TagSubLayerToRemove(subLayer_); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
661 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
662 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
663 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
664 void SetContent(const TextSceneLayer& content) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
665 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
666 SetModified(true); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
667 content_.reset(dynamic_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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
670 virtual bool IsHit(const ScenePoint2D& p, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
671 const Scene2D& scene) const |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
672 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
673 return false; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
674 } |
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 virtual void RenderPolylineLayer(PolylineSceneLayer& polyline, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
677 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
678 { |
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 virtual void RenderOtherLayers(MacroSceneLayer& macro, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
682 const Scene2D& scene) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
683 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
684 if (content_.get() != NULL) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
685 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
686 std::unique_ptr<TextSceneLayer> layer(reinterpret_cast<TextSceneLayer*>(content_->Clone())); |
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 layer->SetColor(IsHover() ? GetHoverColor() : GetColor()); |
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 if (first_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
691 { |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
692 subLayer_ = macro.AddLayer(layer.release()); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
693 first_ = false; |
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 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
696 { |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
697 macro.UpdateLayer(subLayer_, layer.release()); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
698 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
699 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
700 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
701 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
702 virtual void MovePreview(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
703 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
704 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
705 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
706 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
707 virtual void MoveDone(const ScenePoint2D& delta) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
708 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
709 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); // No hit is possible |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
710 } |
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 class EditPrimitiveTracker : public IFlexiblePointerTracker |
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 private: |
1801 | 717 GeometricPrimitive& primitive_; |
718 ScenePoint2D sceneClick_; | |
719 AffineTransform2D canvasToScene_; | |
720 bool alive_; | |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
721 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
722 public: |
1801 | 723 EditPrimitiveTracker(GeometricPrimitive& primitive, |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
724 const ScenePoint2D& sceneClick, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
725 const AffineTransform2D& canvasToScene) : |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
726 primitive_(primitive), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
727 sceneClick_(sceneClick), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
728 canvasToScene_(canvasToScene), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
729 alive_(true) |
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 } |
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 virtual void PointerMove(const PointerEvent& event) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
734 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
735 primitive_.MovePreview(event.GetMainPosition().Apply(canvasToScene_) - sceneClick_); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
736 } |
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 virtual void PointerUp(const PointerEvent& event) ORTHANC_OVERRIDE |
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 primitive_.MoveDone(event.GetMainPosition().Apply(canvasToScene_) - sceneClick_); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
741 alive_ = false; |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
744 virtual void PointerDown(const PointerEvent& event) ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
745 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
746 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
747 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
748 virtual bool IsAlive() const ORTHANC_OVERRIDE |
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 return alive_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
751 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
752 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
753 virtual void Cancel() ORTHANC_OVERRIDE |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
754 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
755 primitive_.MoveDone(ScenePoint2D(0, 0)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
756 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
757 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
758 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
759 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
760 class SegmentAnnotation : public Annotation |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
761 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
762 private: |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
763 bool showLabel_; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
764 Handle& handle1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
765 Handle& handle2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
766 Segment& segment_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
767 Text& label_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
768 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
769 void UpdateLabel() |
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 if (showLabel_) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
772 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
773 TextSceneLayer content; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
774 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
775 double x1 = handle1_.GetCenter().GetX(); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
776 double y1 = handle1_.GetCenter().GetY(); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
777 double x2 = handle2_.GetCenter().GetX(); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
778 double y2 = handle2_.GetCenter().GetY(); |
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 // 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
|
781 if (x1 < x2) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
782 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
783 content.SetPosition(x2, y2); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
784 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
785 else |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
786 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
787 content.SetPosition(x1, y1); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
788 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
789 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
790 content.SetAnchor(BitmapAnchor_CenterLeft); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
791 content.SetBorder(10); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
792 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
793 double dx = x1 - x2; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
794 double dy = y1 - y2; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
795 char buf[32]; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
796 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
|
797 content.SetText(buf); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
798 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
799 label_.SetContent(content); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
800 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
801 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
802 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
803 public: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
804 SegmentAnnotation(AnnotationsLayer& that, |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
805 bool showLabel, |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
806 const ScenePoint2D& p1, |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
807 const ScenePoint2D& p2) : |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
808 Annotation(that), |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
809 showLabel_(showLabel), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
810 handle1_(AddTypedPrimitive<Handle>(new Handle(*this, p1))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
811 handle2_(AddTypedPrimitive<Handle>(new Handle(*this, p2))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
812 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
|
813 label_(AddTypedPrimitive<Text>(new Text(that, *this))) |
1796
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 label_.SetColor(Color(255, 0, 0)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
816 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
817 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
818 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
819 Handle& GetHandle1() const |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
820 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
821 return handle1_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
822 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
823 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
824 Handle& GetHandle2() const |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
825 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
826 return handle2_; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
827 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
828 |
1801 | 829 virtual void SignalMove(GeometricPrimitive& primitive) ORTHANC_OVERRIDE |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
830 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
831 if (&primitive == &handle1_ || |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
832 &primitive == &handle2_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
833 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
834 segment_.SetPosition(handle1_.GetCenter(), handle2_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
835 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
836 else if (&primitive == &segment_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
837 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
838 handle1_.SetCenter(segment_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
839 handle2_.SetCenter(segment_.GetPosition2()); |
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 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
842 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
843 } |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
844 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
845 virtual void Serialize(Json::Value& target) ORTHANC_OVERRIDE |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
846 { |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
847 target = Json::objectValue; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
848 target[KEY_TYPE] = VALUE_SEGMENT; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
849 target[KEY_X1] = handle1_.GetCenter().GetX(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
850 target[KEY_Y1] = handle1_.GetCenter().GetY(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
851 target[KEY_X2] = handle2_.GetCenter().GetX(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
852 target[KEY_Y2] = handle2_.GetCenter().GetY(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
853 } |
1800
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
854 |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
855 static void Unserialize(AnnotationsLayer& target, |
1800
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
856 const Json::Value& source) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
857 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
858 if (source.isMember(KEY_X1) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
859 source.isMember(KEY_Y1) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
860 source.isMember(KEY_X2) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
861 source.isMember(KEY_Y2) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
862 source[KEY_X1].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
863 source[KEY_Y1].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
864 source[KEY_X2].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
865 source[KEY_Y2].isNumeric()) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
866 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
867 new SegmentAnnotation(target, true, |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
868 ScenePoint2D(source[KEY_X1].asDouble(), source[KEY_Y1].asDouble()), |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
869 ScenePoint2D(source[KEY_X2].asDouble(), source[KEY_Y2].asDouble())); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
870 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
871 else |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
872 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
873 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot unserialize an segment annotation"); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
874 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
875 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
876 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
877 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
878 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
879 class AngleAnnotation : public Annotation |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
880 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
881 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
882 Handle& startHandle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
883 Handle& middleHandle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
884 Handle& endHandle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
885 Segment& segment1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
886 Segment& segment2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
887 Arc& arc_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
888 Text& label_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
889 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
890 void UpdateLabel() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
891 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
892 TextSceneLayer content; |
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 const double x1 = startHandle_.GetCenter().GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
895 const double x2 = middleHandle_.GetCenter().GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
896 const double y2 = middleHandle_.GetCenter().GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
897 const double x3 = endHandle_.GetCenter().GetX(); |
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 if (x2 < x1 && |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
900 x2 < x3) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
901 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
902 content.SetAnchor(BitmapAnchor_CenterRight); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
903 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
904 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
905 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
906 content.SetAnchor(BitmapAnchor_CenterLeft); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
907 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
908 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
909 content.SetPosition(x2, y2); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
910 content.SetBorder(10); |
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 char buf[32]; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
913 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
|
914 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
|
915 content.SetText(buf); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
916 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
917 label_.SetContent(content); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
918 } |
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 public: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
921 AngleAnnotation(AnnotationsLayer& that, |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
922 const ScenePoint2D& start, |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
923 const ScenePoint2D& middle, |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
924 const ScenePoint2D& end) : |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
925 Annotation(that), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
926 startHandle_(AddTypedPrimitive<Handle>(new Handle(*this, start))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
927 middleHandle_(AddTypedPrimitive<Handle>(new Handle(*this, middle))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
928 endHandle_(AddTypedPrimitive<Handle>(new Handle(*this, end))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
929 segment1_(AddTypedPrimitive<Segment>(new Segment(*this, start, middle))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
930 segment2_(AddTypedPrimitive<Segment>(new Segment(*this, middle, end))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
931 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
|
932 label_(AddTypedPrimitive<Text>(new Text(that, *this))) |
1796
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 label_.SetColor(Color(255, 0, 0)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
935 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
936 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
937 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
938 Handle& GetEndHandle() const |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
939 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
940 return endHandle_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
941 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
942 |
1801 | 943 virtual void SignalMove(GeometricPrimitive& primitive) ORTHANC_OVERRIDE |
1796
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 if (&primitive == &startHandle_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
946 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
947 segment1_.SetPosition(startHandle_.GetCenter(), middleHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
948 arc_.SetStart(startHandle_.GetCenter()); |
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 else if (&primitive == &middleHandle_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
951 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
952 segment1_.SetPosition(startHandle_.GetCenter(), middleHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
953 segment2_.SetPosition(middleHandle_.GetCenter(), endHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
954 arc_.SetMiddle(middleHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
955 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
956 else if (&primitive == &endHandle_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
957 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
958 segment2_.SetPosition(middleHandle_.GetCenter(), endHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
959 arc_.SetEnd(endHandle_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
960 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
961 else if (&primitive == &segment1_) |
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 startHandle_.SetCenter(segment1_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
964 middleHandle_.SetCenter(segment1_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
965 segment2_.SetPosition(segment1_.GetPosition2(), segment2_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
966 arc_.SetStart(segment1_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
967 arc_.SetMiddle(segment1_.GetPosition2()); |
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 else if (&primitive == &segment2_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
970 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
971 middleHandle_.SetCenter(segment2_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
972 endHandle_.SetCenter(segment2_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
973 segment1_.SetPosition(segment1_.GetPosition1(), segment2_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
974 arc_.SetMiddle(segment2_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
975 arc_.SetEnd(segment2_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
976 } |
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 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
979 } |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
980 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
981 virtual void Serialize(Json::Value& target) ORTHANC_OVERRIDE |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
982 { |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
983 target = Json::objectValue; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
984 target[KEY_TYPE] = VALUE_ANGLE; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
985 target[KEY_X1] = startHandle_.GetCenter().GetX(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
986 target[KEY_Y1] = startHandle_.GetCenter().GetY(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
987 target[KEY_X2] = middleHandle_.GetCenter().GetX(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
988 target[KEY_Y2] = middleHandle_.GetCenter().GetY(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
989 target[KEY_X3] = endHandle_.GetCenter().GetX(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
990 target[KEY_Y3] = endHandle_.GetCenter().GetY(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
991 } |
1800
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
992 |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
993 static void Unserialize(AnnotationsLayer& target, |
1800
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
994 const Json::Value& source) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
995 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
996 if (source.isMember(KEY_X1) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
997 source.isMember(KEY_Y1) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
998 source.isMember(KEY_X2) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
999 source.isMember(KEY_Y2) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1000 source.isMember(KEY_X3) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1001 source.isMember(KEY_Y3) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1002 source[KEY_X1].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1003 source[KEY_Y1].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1004 source[KEY_X2].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1005 source[KEY_Y2].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1006 source[KEY_X3].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1007 source[KEY_Y3].isNumeric()) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1008 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1009 new AngleAnnotation(target, |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1010 ScenePoint2D(source[KEY_X1].asDouble(), source[KEY_Y1].asDouble()), |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1011 ScenePoint2D(source[KEY_X2].asDouble(), source[KEY_Y2].asDouble()), |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1012 ScenePoint2D(source[KEY_X3].asDouble(), source[KEY_Y3].asDouble())); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1013 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1014 else |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1015 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1016 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot unserialize an angle annotation"); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1017 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1018 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1019 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1020 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1021 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1022 class CircleAnnotation : public Annotation |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1023 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1024 private: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1025 Handle& handle1_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1026 Handle& handle2_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1027 Segment& segment_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1028 Circle& circle_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1029 Text& label_; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1030 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1031 void UpdateLabel() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1032 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1033 TextSceneLayer content; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1034 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1035 double x1 = handle1_.GetCenter().GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1036 double y1 = handle1_.GetCenter().GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1037 double x2 = handle2_.GetCenter().GetX(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1038 double y2 = handle2_.GetCenter().GetY(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1039 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1040 // 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
|
1041 if (x1 < x2) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1042 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1043 content.SetPosition(x2, y2); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1044 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1045 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1046 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1047 content.SetPosition(x1, y1); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1048 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1049 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1050 content.SetAnchor(BitmapAnchor_CenterLeft); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1051 content.SetBorder(10); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1052 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1053 double dx = x1 - x2; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1054 double dy = y1 - y2; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1055 double diameter = sqrt(dx * dx + dy * dy); // in millimeters |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1056 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1057 double area = PI * diameter * diameter / 4.0; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1058 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1059 char buf[32]; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1060 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
|
1061 diameter / 10.0, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1062 area / 100.0, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1063 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
|
1064 content.SetText(buf); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1065 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1066 label_.SetContent(content); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1067 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1068 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1069 public: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1070 CircleAnnotation(AnnotationsLayer& that, |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1071 const ScenePoint2D& p1, |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1072 const ScenePoint2D& p2) : |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1073 Annotation(that), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1074 handle1_(AddTypedPrimitive<Handle>(new Handle(*this, p1))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1075 handle2_(AddTypedPrimitive<Handle>(new Handle(*this, p2))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1076 segment_(AddTypedPrimitive<Segment>(new Segment(*this, p1, p2))), |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1077 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
|
1078 label_(AddTypedPrimitive<Text>(new Text(that, *this))) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1079 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1080 label_.SetColor(Color(255, 0, 0)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1081 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1082 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1083 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1084 Handle& GetHandle2() const |
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 return handle2_; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1087 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1088 |
1801 | 1089 virtual void SignalMove(GeometricPrimitive& primitive) ORTHANC_OVERRIDE |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1090 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1091 if (&primitive == &handle1_ || |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1092 &primitive == &handle2_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1093 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1094 segment_.SetPosition(handle1_.GetCenter(), handle2_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1095 circle_.SetPosition(handle1_.GetCenter(), handle2_.GetCenter()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1096 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1097 else if (&primitive == &segment_) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1098 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1099 handle1_.SetCenter(segment_.GetPosition1()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1100 handle2_.SetCenter(segment_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1101 circle_.SetPosition(segment_.GetPosition1(), segment_.GetPosition2()); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1102 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1103 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1104 UpdateLabel(); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1105 } |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1106 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1107 virtual void Serialize(Json::Value& target) ORTHANC_OVERRIDE |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1108 { |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1109 target = Json::objectValue; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1110 target[KEY_TYPE] = VALUE_CIRCLE; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1111 target[KEY_X1] = handle1_.GetCenter().GetX(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1112 target[KEY_Y1] = handle1_.GetCenter().GetY(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1113 target[KEY_X2] = handle2_.GetCenter().GetX(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1114 target[KEY_Y2] = handle2_.GetCenter().GetY(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1115 } |
1800
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1116 |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1117 static void Unserialize(AnnotationsLayer& target, |
1800
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1118 const Json::Value& source) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1119 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1120 if (source.isMember(KEY_X1) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1121 source.isMember(KEY_Y1) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1122 source.isMember(KEY_X2) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1123 source.isMember(KEY_Y2) && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1124 source[KEY_X1].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1125 source[KEY_Y1].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1126 source[KEY_X2].isNumeric() && |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1127 source[KEY_Y2].isNumeric()) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1128 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1129 new CircleAnnotation(target, |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1130 ScenePoint2D(source[KEY_X1].asDouble(), source[KEY_Y1].asDouble()), |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1131 ScenePoint2D(source[KEY_X2].asDouble(), source[KEY_Y2].asDouble())); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1132 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1133 else |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1134 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1135 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot unserialize an circle annotation"); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1136 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1137 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1138 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1139 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1140 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1141 class CreateSegmentOrCircleTracker : public IFlexiblePointerTracker |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1142 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1143 private: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1144 AnnotationsLayer& that_; |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1145 Annotation* annotation_; |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1146 AffineTransform2D canvasToScene_; |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1147 Handle* handle2_; |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1148 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1149 public: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1150 CreateSegmentOrCircleTracker(AnnotationsLayer& that, |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1151 bool isCircle, |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1152 const ScenePoint2D& sceneClick, |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1153 const AffineTransform2D& canvasToScene) : |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1154 that_(that), |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1155 annotation_(NULL), |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1156 canvasToScene_(canvasToScene), |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1157 handle2_(NULL) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1158 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1159 if (isCircle) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1160 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1161 annotation_ = new CircleAnnotation(that, sceneClick, sceneClick); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1162 handle2_ = &dynamic_cast<CircleAnnotation*>(annotation_)->GetHandle2(); |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1163 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1164 else |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1165 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1166 annotation_ = new SegmentAnnotation(that, true /* show label */, sceneClick, sceneClick); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1167 handle2_ = &dynamic_cast<SegmentAnnotation*>(annotation_)->GetHandle2(); |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1168 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1169 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1170 assert(annotation_ != NULL && |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1171 handle2_ != NULL); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1172 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1173 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1174 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
|
1175 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1176 if (annotation_ != NULL) |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1177 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1178 assert(handle2_ != NULL); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1179 handle2_->SetCenter(event.GetMainPosition().Apply(canvasToScene_)); |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1180 annotation_->SignalMove(*handle2_); |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1181 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1182 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1183 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1184 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
|
1185 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1186 annotation_ = NULL; // IsAlive() becomes false |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1187 |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1188 that_.BroadcastMessage(AnnotationAddedMessage(that_)); |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1189 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1190 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1191 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
|
1192 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1193 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1194 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1195 virtual bool IsAlive() const ORTHANC_OVERRIDE |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1196 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1197 return (annotation_ != NULL); |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1198 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1199 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1200 virtual void Cancel() ORTHANC_OVERRIDE |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1201 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1202 if (annotation_ != NULL) |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1203 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1204 that_.DeleteAnnotation(annotation_); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1205 annotation_ = NULL; |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1206 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1207 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1208 }; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1209 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1210 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1211 class CreateAngleTracker : public IFlexiblePointerTracker |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1212 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1213 private: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1214 AnnotationsLayer& that_; |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1215 SegmentAnnotation* segment_; |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1216 AngleAnnotation* angle_; |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1217 AffineTransform2D canvasToScene_; |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1218 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1219 public: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1220 CreateAngleTracker(AnnotationsLayer& that, |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1221 const ScenePoint2D& sceneClick, |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1222 const AffineTransform2D& canvasToScene) : |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1223 that_(that), |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1224 segment_(NULL), |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1225 angle_(NULL), |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1226 canvasToScene_(canvasToScene) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1227 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1228 segment_ = new SegmentAnnotation(that, false /* no length label */, sceneClick, sceneClick); |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1229 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1230 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1231 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
|
1232 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1233 if (segment_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1234 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1235 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
|
1236 segment_->SignalMove(segment_->GetHandle2()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1237 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1238 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1239 if (angle_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1240 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1241 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
|
1242 angle_->SignalMove(angle_->GetEndHandle()); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1243 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1244 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1245 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1246 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
|
1247 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1248 if (segment_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1249 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1250 // 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
|
1251 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1252 angle_ = new AngleAnnotation(that_, segment_->GetHandle1().GetCenter(), |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1253 segment_->GetHandle2().GetCenter(), |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1254 segment_->GetHandle2().GetCenter()); |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1255 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1256 that_.DeleteAnnotation(segment_); |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1257 segment_ = NULL; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1258 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1259 else |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1260 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1261 angle_ = NULL; // IsAlive() becomes false |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1262 |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1263 that_.BroadcastMessage(AnnotationAddedMessage(that_)); |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1264 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1265 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1266 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1267 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
|
1268 { |
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 virtual bool IsAlive() const ORTHANC_OVERRIDE |
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 (segment_ != NULL || |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1274 angle_ != NULL); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1275 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1276 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1277 virtual void Cancel() ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1278 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1279 if (segment_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1280 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1281 that_.DeleteAnnotation(segment_); |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1282 segment_ = NULL; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1283 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1284 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1285 if (angle_ != NULL) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1286 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1287 that_.DeleteAnnotation(angle_); |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1288 angle_ = NULL; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1289 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1290 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1291 }; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1292 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1293 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1294 // 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
|
1295 // 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
|
1296 class EraseTracker : public IFlexiblePointerTracker |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1297 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1298 public: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1299 EraseTracker() |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1300 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1301 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1302 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1303 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
|
1304 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1305 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1306 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1307 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
|
1308 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1309 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1310 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1311 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
|
1312 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1313 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1314 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1315 virtual bool IsAlive() const ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1316 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1317 return false; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1318 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1319 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1320 virtual void Cancel() ORTHANC_OVERRIDE |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1321 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1322 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1323 }; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1324 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1325 |
1801 | 1326 typedef std::set<GeometricPrimitive*> GeometricPrimitives; |
1327 typedef std::set<Annotation*> Annotations; | |
1328 typedef std::set<size_t> SubLayers; | |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1329 |
1801 | 1330 Tool activeTool_; |
1331 size_t macroLayerIndex_; | |
1332 size_t polylineSubLayer_; | |
1333 GeometricPrimitives primitives_; | |
1334 Annotations annotations_; | |
1335 SubLayers subLayersToRemove_; | |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1336 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1337 void AddAnnotation(Annotation* annotation) |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1338 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1339 assert(annotation != NULL); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1340 assert(annotations_.find(annotation) == annotations_.end()); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1341 annotations_.insert(annotation); |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1342 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1343 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1344 void DeleteAnnotation(Annotation* annotation) |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1345 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1346 if (annotation != NULL) |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1347 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1348 assert(annotations_.find(annotation) != annotations_.end()); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1349 annotations_.erase(annotation); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1350 delete annotation; |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1351 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1352 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1353 |
1801 | 1354 void DeletePrimitive(GeometricPrimitive* primitive) |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1355 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1356 if (primitive != NULL) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1357 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1358 assert(primitives_.find(primitive) != primitives_.end()); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1359 primitives_.erase(primitive); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1360 delete primitive; |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1361 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1362 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1363 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1364 void TagSubLayerToRemove(size_t subLayerIndex) |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1365 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1366 assert(subLayersToRemove_.find(subLayerIndex) == subLayersToRemove_.end()); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1367 subLayersToRemove_.insert(subLayerIndex); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1368 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1369 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1370 public: |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1371 AnnotationsLayer(size_t macroLayerIndex) : |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1372 activeTool_(Tool_Edit), |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1373 macroLayerIndex_(macroLayerIndex), |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1374 polylineSubLayer_(0) // dummy initialization |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1375 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1376 annotations_.insert(new SegmentAnnotation(*this, true /* show label */, ScenePoint2D(0, 0), ScenePoint2D(100, 100))); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1377 annotations_.insert(new AngleAnnotation(*this, ScenePoint2D(100, 50), ScenePoint2D(150, 40), ScenePoint2D(200, 50))); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1378 annotations_.insert(new CircleAnnotation(*this, ScenePoint2D(50, 200), ScenePoint2D(100, 250))); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1379 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1380 |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1381 ~AnnotationsLayer() |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1382 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1383 Clear(); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1384 } |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1385 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1386 void Clear() |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1387 { |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1388 for (Annotations::iterator it = annotations_.begin(); it != annotations_.end(); ++it) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1389 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1390 assert(*it != NULL); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1391 delete *it; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1392 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1393 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1394 annotations_.clear(); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1395 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1396 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1397 void SetActiveTool(Tool tool) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1398 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1399 activeTool_ = tool; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1400 } |
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 Tool GetActiveTool() const |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1403 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1404 return activeTool_; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1405 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1406 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1407 void Render(Scene2D& scene) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1408 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1409 MacroSceneLayer* macro = NULL; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1410 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1411 if (scene.HasLayer(macroLayerIndex_)) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1412 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1413 macro = &dynamic_cast<MacroSceneLayer&>(scene.GetLayer(macroLayerIndex_)); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1414 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1415 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1416 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1417 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
|
1418 polylineSubLayer_ = macro->AddLayer(new PolylineSceneLayer); |
1796
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 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1421 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
|
1422 { |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1423 assert(macro->HasLayer(*it)); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1424 macro->DeleteLayer(*it); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1425 } |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1426 |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1427 subLayersToRemove_.clear(); |
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1428 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1429 std::unique_ptr<PolylineSceneLayer> polyline(new PolylineSceneLayer); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1430 |
1801 | 1431 for (GeometricPrimitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1432 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1433 assert(*it != NULL); |
1801 | 1434 GeometricPrimitive& primitive = **it; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1435 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1436 primitive.RenderPolylineLayer(*polyline, scene); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1437 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1438 if (primitive.IsModified()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1439 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1440 primitive.RenderOtherLayers(*macro, scene); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1441 primitive.SetModified(false); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1442 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1443 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1444 |
1797
013dec434a84
creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1796
diff
changeset
|
1445 macro->UpdateLayer(polylineSubLayer_, polyline.release()); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1446 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1447 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1448 bool ClearHover() |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1449 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1450 bool needsRefresh = false; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1451 |
1801 | 1452 for (GeometricPrimitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1453 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1454 assert(*it != NULL); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1455 if ((*it)->IsHover()) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1456 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1457 (*it)->SetHover(false); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1458 needsRefresh = true; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1459 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1460 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1461 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1462 return needsRefresh; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1463 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1464 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1465 bool SetMouseHover(const ScenePoint2D& p /* expressed in canvas coordinates */, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1466 const Scene2D& scene) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1467 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1468 if (activeTool_ == Tool_None) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1469 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1470 return ClearHover(); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1471 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1472 else |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1473 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1474 bool needsRefresh = false; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1475 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1476 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
|
1477 |
1801 | 1478 for (GeometricPrimitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1479 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1480 assert(*it != NULL); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1481 bool hover = (*it)->IsHit(s, scene); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1482 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1483 if ((*it)->IsHover() != hover) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1484 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1485 needsRefresh = true; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1486 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1487 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1488 (*it)->SetHover(hover); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1489 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1490 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1491 return needsRefresh; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1492 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1493 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1494 |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1495 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1496 IFlexiblePointerTracker* CreateTracker(const ScenePoint2D& p /* expressed in canvas coordinates */, |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1497 const Scene2D& scene) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1498 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1499 if (activeTool_ == Tool_None) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1500 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1501 return NULL; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1502 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1503 else |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1504 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1505 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
|
1506 |
1801 | 1507 GeometricPrimitive* bestHit = NULL; |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1508 |
1801 | 1509 for (GeometricPrimitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it) |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1510 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1511 assert(*it != NULL); |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1512 if ((*it)->IsHit(s, scene)) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1513 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1514 if (bestHit == NULL || |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1515 bestHit->GetDepth() > (*it)->GetDepth()) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1516 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1517 bestHit = *it; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1518 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1519 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1520 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1521 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1522 if (bestHit != NULL) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1523 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1524 if (activeTool_ == Tool_Erase) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1525 { |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1526 DeleteAnnotation(&bestHit->GetParentAnnotation()); |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1527 BroadcastMessage(AnnotationRemovedMessage(*this)); |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1528 return new EraseTracker; |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1529 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1530 else |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1531 { |
1798
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1532 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
|
1533 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1534 } |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1535 else |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1536 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1537 switch (activeTool_) |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1538 { |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1539 case Tool_Segment: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1540 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
|
1541 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1542 case Tool_Circle: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1543 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
|
1544 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1545 case Tool_Angle: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1546 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
|
1547 |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1548 default: |
41f3872bd7d2
create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1797
diff
changeset
|
1549 return NULL; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1550 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1551 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1552 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1553 } |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1554 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1555 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1556 void Serialize(Json::Value& target) const |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1557 { |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1558 Json::Value annotations = Json::arrayValue; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1559 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1560 for (Annotations::const_iterator it = annotations_.begin(); it != annotations_.end(); ++it) |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1561 { |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1562 assert(*it != NULL); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1563 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1564 Json::Value item; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1565 (*it)->Serialize(item); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1566 annotations.append(item); |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1567 } |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1568 |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1569 target = Json::objectValue; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1570 target[KEY_ANNOTATIONS] = annotations; |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1571 } |
1800
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1572 |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1573 |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1574 void Unserialize(const Json::Value& serialized) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1575 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1576 Clear(); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1577 |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1578 if (serialized.type() != Json::objectValue || |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1579 !serialized.isMember(KEY_ANNOTATIONS) || |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1580 serialized[KEY_ANNOTATIONS].type() != Json::arrayValue) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1581 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1582 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot unserialize a set of annotations"); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1583 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1584 |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1585 const Json::Value& annotations = serialized[KEY_ANNOTATIONS]; |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1586 |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1587 for (Json::Value::ArrayIndex i = 0; i < annotations.size(); i++) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1588 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1589 if (annotations[i].type() != Json::objectValue || |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1590 !annotations[i].isMember(KEY_TYPE) || |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1591 annotations[i][KEY_TYPE].type() != Json::stringValue) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1592 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1593 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1594 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1595 |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1596 const std::string& type = annotations[i][KEY_TYPE].asString(); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1597 |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1598 if (type == VALUE_ANGLE) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1599 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1600 AngleAnnotation::Unserialize(*this, annotations[i]); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1601 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1602 else if (type == VALUE_CIRCLE) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1603 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1604 CircleAnnotation::Unserialize(*this, annotations[i]); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1605 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1606 else if (type == VALUE_SEGMENT) |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1607 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1608 SegmentAnnotation::Unserialize(*this, annotations[i]); |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1609 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1610 else |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1611 { |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1612 LOG(ERROR) << "Cannot unserialize unknown type of annotation: " << type; |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1613 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1614 } |
2c0497d61a5d
unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1799
diff
changeset
|
1615 } |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1616 }; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1617 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1618 #endif |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1619 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1620 |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1621 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1622 std::string orthancUrl; |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1623 std::string instanceId; |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1624 int frameIndex = 0; |
1368 | 1625 |
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
|
1626 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1627 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
|
1628 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1629 namespace po = boost::program_options; |
1532
c7a37c3a0b8e
print help in sdl samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1512
diff
changeset
|
1630 po::options_description desc("Usage"); |
1368 | 1631 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1632 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
|
1633 ("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
|
1634 "You can choose WARNING, INFO or TRACE for the logging level: Errors and warnings will always be displayed. (default: WARNING)") |
1368 | 1635 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1636 ("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
|
1637 "Base URL of the Orthanc instance") |
1368 | 1638 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1639 ("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
|
1640 "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
|
1641 |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1642 ("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
|
1643 "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
|
1644 ; |
1368 | 1645 |
1532
c7a37c3a0b8e
print help in sdl samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1512
diff
changeset
|
1646 std::cout << desc << std::endl; |
c7a37c3a0b8e
print help in sdl samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1512
diff
changeset
|
1647 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1648 std::cout << std::endl << "Keyboard shorcuts:" << std::endl |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1649 << " a\tEnable/disable the angle annotation tool" << std::endl |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1650 << " f\tToggle fullscreen display" << std::endl |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1651 << " l\tEnable/disable the line annotation tool" << std::endl |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1652 << " q\tExit" << std::endl |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1653 << " r\tRedo the last edit to the annotation tools" << std::endl |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1654 << " s\tFit the viewpoint to the image" << std::endl |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1655 << " u\tUndo the last edit to the annotation tools" << std::endl |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1656 << std::endl << "Mouse buttons:" << std::endl |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1657 << " left \tChange windowing, or edit annotation" << std::endl |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1658 << " center\tMove the viewpoint, or edit annotation" << std::endl |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1659 << " right \tZoom, or edit annotation" << std::endl |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1660 << std::endl; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1661 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1662 po::variables_map vm; |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1663 try |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1664 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1665 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
|
1666 po::notify(vm); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1667 } |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1668 catch (std::exception& e) |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1669 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1670 std::cerr << "Please check your command line options! (\"" << e.what() << "\")" << std::endl; |
1368 | 1671 } |
1672 | |
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
|
1673 if (vm.count("loglevel") > 0) |
1368 | 1674 { |
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
|
1675 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
|
1676 OrthancStoneHelpers::SetLogLevel(logLevel); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1677 } |
1368 | 1678 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1679 if (vm.count("orthanc") > 0) |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1680 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1681 // maybe check URL validity here |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1682 orthancUrl = vm["orthanc"].as<std::string>(); |
1368 | 1683 } |
1684 | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1685 if (vm.count("instance") > 0) |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1686 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1687 instanceId = vm["instance"].as<std::string>(); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1688 } |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1689 |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1690 if (vm.count("frame_index") > 0) |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1691 { |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1692 frameIndex = vm["frame_index"].as<int>(); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1693 } |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1694 } |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1695 |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1696 |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1697 enum ActiveTool |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1698 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1699 ActiveTool_None, |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1700 ActiveTool_Line, |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1701 ActiveTool_Angle |
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 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1704 |
1368 | 1705 /** |
1706 * IMPORTANT: The full arguments to "main()" are needed for SDL on | |
1707 * Windows. Otherwise, one gets the linking error "undefined reference | |
1708 * to `SDL_main'". https://wiki.libsdl.org/FAQWindows | |
1709 **/ | |
1710 int main(int argc, char* argv[]) | |
1711 { | |
1712 try | |
1713 { | |
1714 OrthancStone::StoneInitialize(); | |
1591
5887a4f8594b
moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1576
diff
changeset
|
1715 OrthancStone::SdlWindow::GlobalInitialize(); |
5887a4f8594b
moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1576
diff
changeset
|
1716 |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1717 ProcessOptions(argc, argv); |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1718 |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1719 //Orthanc::Logging::EnableInfoLevel(true); |
1368 | 1720 //Orthanc::Logging::EnableTraceLevel(true); |
1721 | |
1722 { | |
1723 | |
1724 #if 1 | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1725 boost::shared_ptr<OrthancStone::SdlViewport> viewport = |
1368 | 1726 OrthancStone::SdlOpenGLViewport::Create("Stone of Orthanc", 800, 600); |
1727 #else | |
1728 boost::shared_ptr<OrthancStone::SdlViewport> viewport = | |
1729 OrthancStone::SdlCairoViewport::Create("Stone of Orthanc", 800, 600); | |
1730 #endif | |
1731 | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1732 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
|
1733 |
1368 | 1734 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
|
1735 |
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
|
1736 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
|
1737 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
|
1738 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
|
1739 |
1368 | 1740 context.StartOracle(); |
1741 | |
1742 { | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1743 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1744 std::string font; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1745 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
|
1746 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1747 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
|
1748 lock->GetCompositor().SetFont(0, font, 16, Orthanc::Encoding_Latin1); |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1749 //lock->GetController().SetUndoStack(undoStack); |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1750 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1751 |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1752 ActiveTool activeTool = ActiveTool_None; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1753 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1754 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
|
1755 bool lineMeasureFirst = true; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1756 lineMeasureTool->Disable(); |
1368 | 1757 |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1758 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
|
1759 bool angleMeasureFirst = true; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1760 angleMeasureTool->Disable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1761 |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1762 OrthancStone::AnnotationsLayer annotations(10); |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1763 annotations.SetActiveTool(OrthancStone::AnnotationsLayer::Tool_Angle); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1764 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1765 { |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1766 Json::Value v; |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1767 annotations.Serialize(v); |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1768 std::cout << v.toStyledString() << std::endl; |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1769 annotations.Clear(); |
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1770 annotations.Unserialize(v); |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1771 } |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1772 |
1368 | 1773 boost::shared_ptr<SdlSimpleViewerApplication> application( |
1774 SdlSimpleViewerApplication::Create(context, viewport)); | |
1775 | |
1776 OrthancStone::DicomSource source; | |
1777 | |
1778 application->LoadOrthancFrame(source, instanceId, frameIndex); | |
1779 | |
1780 OrthancStone::DefaultViewportInteractor interactor; | |
1535
301571299212
DefaultViewportInteractor::SetWindowingLayer()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1532
diff
changeset
|
1781 interactor.SetWindowingLayer(0); |
1368 | 1782 |
1783 { | |
1784 int scancodeCount = 0; | |
1785 const uint8_t* keyboardState = SDL_GetKeyboardState(&scancodeCount); | |
1786 | |
1787 bool stop = false; | |
1788 while (!stop) | |
1789 { | |
1790 bool paint = false; | |
1791 SDL_Event event; | |
1792 while (SDL_PollEvent(&event)) | |
1793 { | |
1794 if (event.type == SDL_QUIT) | |
1795 { | |
1796 stop = true; | |
1797 break; | |
1798 } | |
1799 else if (viewport->IsRefreshEvent(event)) | |
1800 { | |
1801 paint = true; | |
1802 } | |
1803 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
|
1804 (event.window.event == SDL_WINDOWEVENT_RESIZED || |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1805 event.window.event == SDL_WINDOWEVENT_SIZE_CHANGED)) |
1368 | 1806 { |
1807 viewport->UpdateSize(event.window.data1, event.window.data2); | |
1808 } | |
1809 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
|
1810 (event.window.event == SDL_WINDOWEVENT_SHOWN || |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1811 event.window.event == SDL_WINDOWEVENT_EXPOSED)) |
1368 | 1812 { |
1576
92fca2b3ba3d
sanitizing the handling of canvas size
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1560
diff
changeset
|
1813 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
|
1814 lock->RefreshCanvasSize(); |
1368 | 1815 } |
1816 else if (event.type == SDL_KEYDOWN && | |
1817 event.key.repeat == 0 /* Ignore key bounce */) | |
1818 { | |
1819 switch (event.key.keysym.sym) | |
1820 { | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1821 case SDLK_f: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1822 viewport->ToggleMaximize(); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1823 break; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1824 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1825 case SDLK_s: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1826 application->FitContent(); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1827 break; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1828 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1829 case SDLK_q: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1830 stop = true; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1831 break; |
1368 | 1832 |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1833 case SDLK_u: |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1834 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1835 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
|
1836 if (lock->GetController().CanUndo()) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1837 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1838 lock->GetController().Undo(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1839 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1840 break; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1841 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1842 |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1843 case SDLK_r: |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1844 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1845 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
|
1846 if (lock->GetController().CanRedo()) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1847 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1848 lock->GetController().Redo(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1849 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1850 break; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1851 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1852 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1853 case SDLK_l: |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1854 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
|
1855 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1856 lineMeasureTool->Disable(); |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1857 activeTool = ActiveTool_None; |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1858 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1859 else |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1860 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1861 if (lineMeasureFirst) |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1862 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1863 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
|
1864 OrthancStone::Extent2D extent; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1865 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
|
1866 if (!extent.IsEmpty()) |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1867 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1868 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
|
1869 lineMeasureTool->Set(p, p); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1870 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1871 lineMeasureFirst = false; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1872 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1873 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1874 lineMeasureTool->Enable(); |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1875 angleMeasureTool->Disable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1876 activeTool = ActiveTool_Line; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1877 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1878 break; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1879 |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1880 case SDLK_a: |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1881 if (activeTool == ActiveTool_Angle) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1882 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1883 angleMeasureTool->Disable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1884 activeTool = ActiveTool_None; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1885 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1886 else |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1887 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1888 if (angleMeasureFirst) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1889 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1890 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
|
1891 OrthancStone::Extent2D extent; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1892 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
|
1893 if (!extent.IsEmpty()) |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1894 { |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1895 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
|
1896 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
|
1897 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
|
1898 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
|
1899 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
|
1900 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
|
1901 angleMeasureTool->SetSide1End(p1); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1902 angleMeasureTool->SetCenter(p2); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1903 angleMeasureTool->SetSide2End(p3); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1904 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1905 angleMeasureFirst = false; |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1906 } |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1907 |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1908 lineMeasureTool->Disable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1909 angleMeasureTool->Enable(); |
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1910 activeTool = ActiveTool_Angle; |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1911 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1912 break; |
1368 | 1913 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1914 default: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1915 break; |
1368 | 1916 } |
1917 } | |
1918 else if (event.type == SDL_MOUSEBUTTONDOWN || | |
1919 event.type == SDL_MOUSEMOTION || | |
1920 event.type == SDL_MOUSEBUTTONUP) | |
1921 { | |
1507
169adf9090a6
replacing deprecated std::auto_ptr by std::unique_ptr
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1458
diff
changeset
|
1922 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
1368 | 1923 if (lock->HasCompositor()) |
1924 { | |
1925 OrthancStone::PointerEvent p; | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1926 OrthancStoneHelpers::GetPointerEvent(p, lock->GetCompositor(), |
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
1927 event, keyboardState, scancodeCount); |
1368 | 1928 |
1929 switch (event.type) | |
1930 { | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1931 case SDL_MOUSEBUTTONDOWN: |
1368 | 1932 { |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1933 boost::shared_ptr<OrthancStone::IFlexiblePointerTracker> t; |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1934 |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1935 if (p.GetMouseButton() == OrthancStone::MouseButton_Left) |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1936 { |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1937 t.reset(annotations.CreateTracker(p.GetMainPosition(), lock->GetController().GetScene())); |
1799
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1938 } |
1125793d82d3
serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1798
diff
changeset
|
1939 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1940 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
|
1941 { |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1942 switch (activeTool) |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1943 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1944 case ActiveTool_Angle: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1945 t = angleMeasureTool->CreateEditionTracker(p); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1946 break; |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1947 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1948 case ActiveTool_Line: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1949 t = lineMeasureTool->CreateEditionTracker(p); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1950 break; |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1951 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1952 case ActiveTool_None: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1953 break; |
1790
b325761e0bd3
angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1789
diff
changeset
|
1954 |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1955 default: |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1956 throw Orthanc::OrthancException(Orthanc::ErrorCode_NotImplemented); |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1957 } |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1958 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1959 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1960 if (t.get() != NULL) |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1961 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1962 lock->GetController().AcquireActiveTracker(t); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1963 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1964 else |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1965 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1966 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
|
1967 lock->GetCompositor().GetCanvasWidth(), |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1968 lock->GetCompositor().GetCanvasHeight()); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1969 } |
1368 | 1970 lock->Invalidate(); |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1971 break; |
1368 | 1972 } |
1973 | |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1974 case SDL_MOUSEMOTION: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1975 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
|
1976 { |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1977 lock->Invalidate(); |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1978 if (annotations.ClearHover()) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1979 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1980 paint = true; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1981 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1982 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1983 else |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1984 { |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
1985 if (annotations.SetMouseHover(p.GetMainPosition(), lock->GetController().GetScene())) |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1986 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1987 paint = true; |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
1988 } |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1989 } |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1990 break; |
1368 | 1991 |
1789
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1992 case SDL_MOUSEBUTTONUP: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1993 lock->GetController().HandleMouseRelease(p); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1994 lock->Invalidate(); |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1995 break; |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1996 |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1997 default: |
462d7a0e064e
added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1739
diff
changeset
|
1998 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
1368 | 1999 } |
2000 } | |
2001 } | |
2002 } | |
2003 | |
2004 if (paint) | |
2005 { | |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
2006 { |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
2007 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock()); |
1803
d1849468729b
added messages to AnnotationsLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1801
diff
changeset
|
2008 annotations.Render(lock->GetController().GetScene()); |
1796
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
2009 } |
20a0aba0ede5
creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1790
diff
changeset
|
2010 |
1368 | 2011 viewport->Paint(); |
2012 } | |
2013 | |
2014 // Small delay to avoid using 100% of CPU | |
2015 SDL_Delay(1); | |
2016 } | |
2017 } | |
2018 context.StopOracle(); | |
2019 } | |
2020 } | |
2021 | |
1591
5887a4f8594b
moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1576
diff
changeset
|
2022 OrthancStone::SdlWindow::GlobalFinalize(); |
1368 | 2023 OrthancStone::StoneFinalize(); |
2024 return 0; | |
2025 } | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
2026 catch (Orthanc::OrthancException& e) |
1368 | 2027 { |
2028 LOG(ERROR) << "OrthancException: " << e.What(); | |
2029 return -1; | |
2030 } | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
2031 catch (OrthancStone::StoneException& e) |
1368 | 2032 { |
2033 LOG(ERROR) << "StoneException: " << e.What(); | |
2034 return -1; | |
2035 } | |
1382
9d138883be66
Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents:
1368
diff
changeset
|
2036 catch (std::runtime_error& e) |
1368 | 2037 { |
2038 LOG(ERROR) << "Runtime error: " << e.what(); | |
2039 return -1; | |
2040 } | |
2041 catch (...) | |
2042 { | |
2043 LOG(ERROR) << "Native exception"; | |
2044 return -1; | |
2045 } | |
2046 } |