annotate Applications/Samples/Sdl/SingleFrameViewer/SdlSimpleViewer.cpp @ 1799:1125793d82d3

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