annotate Applications/Samples/Sdl/SingleFrameViewer/SdlSimpleViewer.cpp @ 1800:2c0497d61a5d

unserialization of annotations
author Sebastien Jodogne <s.jodogne@gmail.com>
date Thu, 20 May 2021 12:05:15 +0200
parents 1125793d82d3
children 64dad1d7aca4
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 {
1800
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
655 if (!first_)
1797
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 }
1800
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
851
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
852 static void Unserialize(AnnotationsOverlay& target,
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
853 const Json::Value& source)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
854 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
855 if (source.isMember(KEY_X1) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
856 source.isMember(KEY_Y1) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
857 source.isMember(KEY_X2) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
858 source.isMember(KEY_Y2) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
859 source[KEY_X1].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
860 source[KEY_Y1].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
861 source[KEY_X2].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
862 source[KEY_Y2].isNumeric())
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
863 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
864 new SegmentAnnotation(target, true,
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
865 ScenePoint2D(source[KEY_X1].asDouble(), source[KEY_Y1].asDouble()),
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
866 ScenePoint2D(source[KEY_X2].asDouble(), source[KEY_Y2].asDouble()));
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
867 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
868 else
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
869 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
870 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot unserialize an segment annotation");
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
871 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
872 }
1796
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
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
875
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
876 class AngleAnnotation : public Annotation
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
877 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
878 private:
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
879 Handle& startHandle_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
880 Handle& middleHandle_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
881 Handle& endHandle_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
882 Segment& segment1_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
883 Segment& segment2_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
884 Arc& arc_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
885 Text& label_;
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 void UpdateLabel()
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
888 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
889 TextSceneLayer content;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
890
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
891 const double x1 = startHandle_.GetCenter().GetX();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
892 const double x2 = middleHandle_.GetCenter().GetX();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
893 const double y2 = middleHandle_.GetCenter().GetY();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
894 const double x3 = endHandle_.GetCenter().GetX();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
895
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
896 if (x2 < x1 &&
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
897 x2 < x3)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
898 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
899 content.SetAnchor(BitmapAnchor_CenterRight);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
900 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
901 else
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
902 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
903 content.SetAnchor(BitmapAnchor_CenterLeft);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
904 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
905
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
906 content.SetPosition(x2, y2);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
907 content.SetBorder(10);
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 char buf[32];
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
910 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
911 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
912 content.SetText(buf);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
913
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
914 label_.SetContent(content);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
915 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
916
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
917 public:
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
918 AngleAnnotation(AnnotationsOverlay& that,
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
919 const ScenePoint2D& start,
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
920 const ScenePoint2D& middle,
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
921 const ScenePoint2D& end) :
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
922 Annotation(that),
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
923 startHandle_(AddTypedPrimitive<Handle>(new Handle(*this, start))),
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
924 middleHandle_(AddTypedPrimitive<Handle>(new Handle(*this, middle))),
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
925 endHandle_(AddTypedPrimitive<Handle>(new Handle(*this, end))),
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
926 segment1_(AddTypedPrimitive<Segment>(new Segment(*this, start, middle))),
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
927 segment2_(AddTypedPrimitive<Segment>(new Segment(*this, middle, end))),
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
928 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
929 label_(AddTypedPrimitive<Text>(new Text(that, *this)))
1796
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 label_.SetColor(Color(255, 0, 0));
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
932 UpdateLabel();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
933 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
934
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
935 Handle& GetEndHandle() const
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
936 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
937 return endHandle_;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
938 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
939
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
940 virtual void SignalMove(Primitive& primitive) ORTHANC_OVERRIDE
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
941 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
942 if (&primitive == &startHandle_)
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 segment1_.SetPosition(startHandle_.GetCenter(), middleHandle_.GetCenter());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
945 arc_.SetStart(startHandle_.GetCenter());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
946 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
947 else if (&primitive == &middleHandle_)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
948 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
949 segment1_.SetPosition(startHandle_.GetCenter(), middleHandle_.GetCenter());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
950 segment2_.SetPosition(middleHandle_.GetCenter(), endHandle_.GetCenter());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
951 arc_.SetMiddle(middleHandle_.GetCenter());
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 else if (&primitive == &endHandle_)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
954 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
955 segment2_.SetPosition(middleHandle_.GetCenter(), endHandle_.GetCenter());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
956 arc_.SetEnd(endHandle_.GetCenter());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
957 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
958 else if (&primitive == &segment1_)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
959 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
960 startHandle_.SetCenter(segment1_.GetPosition1());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
961 middleHandle_.SetCenter(segment1_.GetPosition2());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
962 segment2_.SetPosition(segment1_.GetPosition2(), segment2_.GetPosition2());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
963 arc_.SetStart(segment1_.GetPosition1());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
964 arc_.SetMiddle(segment1_.GetPosition2());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
965 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
966 else if (&primitive == &segment2_)
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 middleHandle_.SetCenter(segment2_.GetPosition1());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
969 endHandle_.SetCenter(segment2_.GetPosition2());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
970 segment1_.SetPosition(segment1_.GetPosition1(), segment2_.GetPosition1());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
971 arc_.SetMiddle(segment2_.GetPosition1());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
972 arc_.SetEnd(segment2_.GetPosition2());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
973 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
974
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
975 UpdateLabel();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
976 }
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
977
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
978 virtual void Serialize(Json::Value& target) ORTHANC_OVERRIDE
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
979 {
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
980 target = Json::objectValue;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
981 target[KEY_TYPE] = VALUE_ANGLE;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
982 target[KEY_X1] = startHandle_.GetCenter().GetX();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
983 target[KEY_Y1] = startHandle_.GetCenter().GetY();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
984 target[KEY_X2] = middleHandle_.GetCenter().GetX();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
985 target[KEY_Y2] = middleHandle_.GetCenter().GetY();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
986 target[KEY_X3] = endHandle_.GetCenter().GetX();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
987 target[KEY_Y3] = endHandle_.GetCenter().GetY();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
988 }
1800
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
989
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
990 static void Unserialize(AnnotationsOverlay& target,
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
991 const Json::Value& source)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
992 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
993 if (source.isMember(KEY_X1) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
994 source.isMember(KEY_Y1) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
995 source.isMember(KEY_X2) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
996 source.isMember(KEY_Y2) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
997 source.isMember(KEY_X3) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
998 source.isMember(KEY_Y3) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
999 source[KEY_X1].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1000 source[KEY_Y1].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1001 source[KEY_X2].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1002 source[KEY_Y2].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1003 source[KEY_X3].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1004 source[KEY_Y3].isNumeric())
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1005 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1006 new AngleAnnotation(target,
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1007 ScenePoint2D(source[KEY_X1].asDouble(), source[KEY_Y1].asDouble()),
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1008 ScenePoint2D(source[KEY_X2].asDouble(), source[KEY_Y2].asDouble()),
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1009 ScenePoint2D(source[KEY_X3].asDouble(), source[KEY_Y3].asDouble()));
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1010 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1011 else
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1012 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1013 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot unserialize an angle annotation");
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1014 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1015 }
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1016 };
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1017
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1018
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1019 class CircleAnnotation : public Annotation
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1020 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1021 private:
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1022 Handle& handle1_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1023 Handle& handle2_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1024 Segment& segment_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1025 Circle& circle_;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1026 Text& label_;
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 void UpdateLabel()
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1029 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1030 TextSceneLayer content;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1031
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1032 double x1 = handle1_.GetCenter().GetX();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1033 double y1 = handle1_.GetCenter().GetY();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1034 double x2 = handle2_.GetCenter().GetX();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1035 double y2 = handle2_.GetCenter().GetY();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1036
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1037 // 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
1038 if (x1 < x2)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1039 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1040 content.SetPosition(x2, y2);
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 else
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1043 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1044 content.SetPosition(x1, y1);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1045 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1046
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1047 content.SetAnchor(BitmapAnchor_CenterLeft);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1048 content.SetBorder(10);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1049
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1050 double dx = x1 - x2;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1051 double dy = y1 - y2;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1052 double diameter = sqrt(dx * dx + dy * dy); // in millimeters
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1053
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1054 double area = PI * diameter * diameter / 4.0;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1055
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1056 char buf[32];
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1057 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
1058 diameter / 10.0,
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1059 area / 100.0,
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1060 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
1061 content.SetText(buf);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1062
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1063 label_.SetContent(content);
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 public:
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1067 CircleAnnotation(AnnotationsOverlay& that,
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1068 const ScenePoint2D& p1,
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1069 const ScenePoint2D& p2) :
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1070 Annotation(that),
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1071 handle1_(AddTypedPrimitive<Handle>(new Handle(*this, p1))),
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1072 handle2_(AddTypedPrimitive<Handle>(new Handle(*this, p2))),
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1073 segment_(AddTypedPrimitive<Segment>(new Segment(*this, p1, p2))),
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1074 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
1075 label_(AddTypedPrimitive<Text>(new Text(that, *this)))
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1076 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1077 label_.SetColor(Color(255, 0, 0));
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1078 UpdateLabel();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1079 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1080
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1081 Handle& GetHandle2() const
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1082 {
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1083 return handle2_;
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
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1086 virtual void SignalMove(Primitive& primitive) ORTHANC_OVERRIDE
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1087 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1088 if (&primitive == &handle1_ ||
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1089 &primitive == &handle2_)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1090 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1091 segment_.SetPosition(handle1_.GetCenter(), handle2_.GetCenter());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1092 circle_.SetPosition(handle1_.GetCenter(), handle2_.GetCenter());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1093 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1094 else if (&primitive == &segment_)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1095 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1096 handle1_.SetCenter(segment_.GetPosition1());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1097 handle2_.SetCenter(segment_.GetPosition2());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1098 circle_.SetPosition(segment_.GetPosition1(), segment_.GetPosition2());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1099 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1100
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1101 UpdateLabel();
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1102 }
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1103
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1104 virtual void Serialize(Json::Value& target) ORTHANC_OVERRIDE
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1105 {
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1106 target = Json::objectValue;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1107 target[KEY_TYPE] = VALUE_CIRCLE;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1108 target[KEY_X1] = handle1_.GetCenter().GetX();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1109 target[KEY_Y1] = handle1_.GetCenter().GetY();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1110 target[KEY_X2] = handle2_.GetCenter().GetX();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1111 target[KEY_Y2] = handle2_.GetCenter().GetY();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1112 }
1800
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1113
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1114 static void Unserialize(AnnotationsOverlay& target,
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1115 const Json::Value& source)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1116 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1117 if (source.isMember(KEY_X1) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1118 source.isMember(KEY_Y1) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1119 source.isMember(KEY_X2) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1120 source.isMember(KEY_Y2) &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1121 source[KEY_X1].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1122 source[KEY_Y1].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1123 source[KEY_X2].isNumeric() &&
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1124 source[KEY_Y2].isNumeric())
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1125 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1126 new CircleAnnotation(target,
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1127 ScenePoint2D(source[KEY_X1].asDouble(), source[KEY_Y1].asDouble()),
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1128 ScenePoint2D(source[KEY_X2].asDouble(), source[KEY_Y2].asDouble()));
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1129 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1130 else
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1131 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1132 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot unserialize an circle annotation");
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1133 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1134 }
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1135 };
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1136
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1137
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1138 class CreateSegmentOrCircleTracker : public IFlexiblePointerTracker
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1139 {
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1140 private:
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1141 AnnotationsOverlay& that_;
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1142 Annotation* annotation_;
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1143 AffineTransform2D canvasToScene_;
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1144 Handle* handle2_;
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1145
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1146 public:
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1147 CreateSegmentOrCircleTracker(AnnotationsOverlay& that,
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1148 bool isCircle,
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1149 const ScenePoint2D& sceneClick,
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1150 const AffineTransform2D& canvasToScene) :
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1151 that_(that),
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1152 annotation_(NULL),
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1153 canvasToScene_(canvasToScene),
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1154 handle2_(NULL)
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1155 {
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1156 if (isCircle)
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1157 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1158 annotation_ = new CircleAnnotation(that, sceneClick, sceneClick);
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1159 handle2_ = &dynamic_cast<CircleAnnotation*>(annotation_)->GetHandle2();
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1160 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1161 else
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1162 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1163 annotation_ = new SegmentAnnotation(that, true /* show label */, sceneClick, sceneClick);
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1164 handle2_ = &dynamic_cast<SegmentAnnotation*>(annotation_)->GetHandle2();
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1165 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1166
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1167 assert(annotation_ != NULL &&
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1168 handle2_ != NULL);
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1169 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1170
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1171 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
1172 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1173 if (annotation_ != NULL)
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1174 {
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1175 assert(handle2_ != NULL);
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1176 handle2_->SetCenter(event.GetMainPosition().Apply(canvasToScene_));
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1177 annotation_->SignalMove(*handle2_);
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1178 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1179 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1180
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1181 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
1182 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1183 annotation_ = NULL; // IsAlive() becomes false
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1184 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1185
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1186 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
1187 {
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1188 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1189
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1190 virtual bool IsAlive() const ORTHANC_OVERRIDE
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1191 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1192 return (annotation_ != NULL);
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1193 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1194
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1195 virtual void Cancel() ORTHANC_OVERRIDE
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1196 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1197 if (annotation_ != NULL)
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1198 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1199 that_.DeleteAnnotation(annotation_);
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1200 annotation_ = NULL;
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1201 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1202 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1203 };
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1204
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1205
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1206 class CreateAngleTracker : public IFlexiblePointerTracker
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1207 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1208 private:
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1209 AnnotationsOverlay& that_;
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1210 SegmentAnnotation* segment_;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1211 AngleAnnotation* angle_;
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1212 AffineTransform2D canvasToScene_;
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 public:
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1215 CreateAngleTracker(AnnotationsOverlay& that,
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1216 const ScenePoint2D& sceneClick,
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1217 const AffineTransform2D& canvasToScene) :
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1218 that_(that),
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1219 segment_(NULL),
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1220 angle_(NULL),
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1221 canvasToScene_(canvasToScene)
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1222 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1223 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
1224 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1225
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1226 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
1227 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1228 if (segment_ != NULL)
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1229 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1230 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
1231 segment_->SignalMove(segment_->GetHandle2());
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
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1234 if (angle_ != NULL)
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 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
1237 angle_->SignalMove(angle_->GetEndHandle());
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 }
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 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
1242 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1243 if (segment_ != NULL)
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 // 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
1246
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1247 angle_ = new AngleAnnotation(that_, segment_->GetHandle1().GetCenter(),
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1248 segment_->GetHandle2().GetCenter(),
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1249 segment_->GetHandle2().GetCenter());
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1250
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1251 that_.DeleteAnnotation(segment_);
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1252 segment_ = NULL;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1253 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1254 else
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1255 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1256 angle_ = NULL; // IsAlive() becomes false
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1257 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1258 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1259
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1260 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
1261 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1262 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1263
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1264 virtual bool IsAlive() const ORTHANC_OVERRIDE
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1265 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1266 return (segment_ != NULL ||
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1267 angle_ != NULL);
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1268 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1269
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1270 virtual void Cancel() ORTHANC_OVERRIDE
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1271 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1272 if (segment_ != NULL)
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1273 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1274 that_.DeleteAnnotation(segment_);
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1275 segment_ = NULL;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1276 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1277
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1278 if (angle_ != NULL)
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1279 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1280 that_.DeleteAnnotation(angle_);
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1281 angle_ = NULL;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1282 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1283 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1284 };
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1285
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1286
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1287 // 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
1288 // 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
1289 class EraseTracker : public IFlexiblePointerTracker
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1290 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1291 public:
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1292 EraseTracker()
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1293 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1294 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1295
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1296 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
1297 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1298 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1299
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1300 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
1301 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1302 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1303
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1304 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
1305 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1306 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1307
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1308 virtual bool IsAlive() const ORTHANC_OVERRIDE
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1309 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1310 return false;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1311 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1312
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1313 virtual void Cancel() ORTHANC_OVERRIDE
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1314 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1315 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1316 };
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1317
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1318
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1319 typedef std::set<Primitive*> Primitives;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1320 typedef std::set<Annotation*> Annotations;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1321 typedef std::set<size_t> SubLayers;
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1322
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1323 Tool activeTool_;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1324 size_t macroLayerIndex_;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1325 size_t polylineSubLayer_;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1326 Primitives primitives_;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1327 Annotations annotations_;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1328 SubLayers subLayersToRemove_;
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1329
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1330 void AddAnnotation(Annotation* annotation)
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1331 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1332 assert(annotation != NULL);
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1333 assert(annotations_.find(annotation) == annotations_.end());
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1334 annotations_.insert(annotation);
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1335 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1336
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1337 void DeleteAnnotation(Annotation* annotation)
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1338 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1339 if (annotation != NULL)
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1340 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1341 assert(annotations_.find(annotation) != annotations_.end());
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1342 annotations_.erase(annotation);
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1343 delete annotation;
1797
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 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1346
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1347 void DeletePrimitive(Primitive* primitive)
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 if (primitive != NULL)
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1350 {
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1351 assert(primitives_.find(primitive) != primitives_.end());
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1352 primitives_.erase(primitive);
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1353 delete primitive;
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1354 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1355 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1356
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1357 void TagSubLayerToRemove(size_t subLayerIndex)
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1358 {
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1359 assert(subLayersToRemove_.find(subLayerIndex) == subLayersToRemove_.end());
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1360 subLayersToRemove_.insert(subLayerIndex);
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1361 }
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1362
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1363 public:
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1364 AnnotationsOverlay(size_t macroLayerIndex) :
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1365 activeTool_(Tool_Edit),
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1366 macroLayerIndex_(macroLayerIndex),
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1367 polylineSubLayer_(0) // dummy initialization
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1368 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1369 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
1370 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
1371 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
1372 }
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 ~AnnotationsOverlay()
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1375 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1376 Clear();
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1377 }
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1378
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1379 void Clear()
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1380 {
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1381 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
1382 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1383 assert(*it != NULL);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1384 delete *it;
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
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1387 annotations_.clear();
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1388 }
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 void SetActiveTool(Tool tool)
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 activeTool_ = tool;
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
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1395 Tool GetActiveTool() const
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1396 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1397 return activeTool_;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1398 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1399
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1400 void Render(Scene2D& scene)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1401 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1402 MacroSceneLayer* macro = NULL;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1403
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1404 if (scene.HasLayer(macroLayerIndex_))
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1405 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1406 macro = &dynamic_cast<MacroSceneLayer&>(scene.GetLayer(macroLayerIndex_));
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1407 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1408 else
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1409 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1410 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
1411 polylineSubLayer_ = macro->AddLayer(new PolylineSceneLayer);
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1412 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1413
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1414 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
1415 {
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1416 assert(macro->HasLayer(*it));
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1417 macro->DeleteLayer(*it);
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1418 }
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1419
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1420 subLayersToRemove_.clear();
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1421
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1422 std::unique_ptr<PolylineSceneLayer> polyline(new PolylineSceneLayer);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1423
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1424 for (Primitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1425 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1426 assert(*it != NULL);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1427 Primitive& primitive = **it;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1428
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1429 primitive.RenderPolylineLayer(*polyline, scene);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1430
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1431 if (primitive.IsModified())
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1432 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1433 primitive.RenderOtherLayers(*macro, scene);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1434 primitive.SetModified(false);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1435 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1436 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1437
1797
013dec434a84 creation of segment or circle measures
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1796
diff changeset
1438 macro->UpdateLayer(polylineSubLayer_, polyline.release());
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1439 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1440
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1441 bool ClearHover()
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1442 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1443 bool needsRefresh = false;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1444
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1445 for (Primitives::iterator it = primitives_.begin(); it != primitives_.end(); ++it)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1446 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1447 assert(*it != NULL);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1448 if ((*it)->IsHover())
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1449 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1450 (*it)->SetHover(false);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1451 needsRefresh = true;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1452 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1453 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1454
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1455 return needsRefresh;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1456 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1457
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1458 bool SetMouseHover(const ScenePoint2D& p /* expressed in canvas coordinates */,
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1459 const Scene2D& scene)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1460 {
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1461 if (activeTool_ == Tool_None)
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 return ClearHover();
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1464 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1465 else
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1466 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1467 bool needsRefresh = false;
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1468
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1469 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
1470
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1471 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
1472 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1473 assert(*it != NULL);
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1474 bool hover = (*it)->IsHit(s, scene);
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1475
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1476 if ((*it)->IsHover() != hover)
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1477 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1478 needsRefresh = true;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1479 }
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1480
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1481 (*it)->SetHover(hover);
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1482 }
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1483
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1484 return needsRefresh;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1485 }
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1486 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1487
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1488
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1489 IFlexiblePointerTracker* CreateTracker(const ScenePoint2D& p /* expressed in canvas coordinates */,
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1490 const Scene2D& scene)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1491 {
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1492 if (activeTool_ == Tool_None)
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1493 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1494 return NULL;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1495 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1496 else
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1497 {
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1498 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
1499
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1500 Primitive* bestHit = NULL;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1501
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1502 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
1503 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1504 assert(*it != NULL);
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1505 if ((*it)->IsHit(s, scene))
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1506 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1507 if (bestHit == NULL ||
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1508 bestHit->GetDepth() > (*it)->GetDepth())
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1509 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1510 bestHit = *it;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1511 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1512 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1513 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1514
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1515 if (bestHit != NULL)
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1516 {
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1517 if (activeTool_ == Tool_Erase)
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1518 {
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1519 DeleteAnnotation(&bestHit->GetParentAnnotation());
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1520 return new EraseTracker;
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1521 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1522 else
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1523 {
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1524 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
1525 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1526 }
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1527 else
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1528 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1529 switch (activeTool_)
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1530 {
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1531 case Tool_Segment:
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1532 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
1533
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1534 case Tool_Circle:
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1535 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
1536
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1537 case Tool_Angle:
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1538 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
1539
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1540 default:
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1541 return NULL;
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1542 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1543 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1544 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1545 }
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1546
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1547
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1548 void Serialize(Json::Value& target) const
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1549 {
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1550 Json::Value annotations = Json::arrayValue;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1551
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1552 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
1553 {
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1554 assert(*it != NULL);
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1555
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1556 Json::Value item;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1557 (*it)->Serialize(item);
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1558 annotations.append(item);
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1559 }
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1560
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1561 target = Json::objectValue;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1562 target[KEY_ANNOTATIONS] = annotations;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1563 }
1800
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1564
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1565
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1566 void Unserialize(const Json::Value& serialized)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1567 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1568 Clear();
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1569
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1570 if (serialized.type() != Json::objectValue ||
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1571 !serialized.isMember(KEY_ANNOTATIONS) ||
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1572 serialized[KEY_ANNOTATIONS].type() != Json::arrayValue)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1573 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1574 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat, "Cannot unserialize a set of annotations");
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1575 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1576
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1577 const Json::Value& annotations = serialized[KEY_ANNOTATIONS];
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1578
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1579 for (Json::Value::ArrayIndex i = 0; i < annotations.size(); i++)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1580 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1581 if (annotations[i].type() != Json::objectValue ||
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1582 !annotations[i].isMember(KEY_TYPE) ||
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1583 annotations[i][KEY_TYPE].type() != Json::stringValue)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1584 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1585 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat);
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1586 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1587
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1588 const std::string& type = annotations[i][KEY_TYPE].asString();
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1589
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1590 if (type == VALUE_ANGLE)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1591 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1592 AngleAnnotation::Unserialize(*this, annotations[i]);
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1593 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1594 else if (type == VALUE_CIRCLE)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1595 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1596 CircleAnnotation::Unserialize(*this, annotations[i]);
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1597 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1598 else if (type == VALUE_SEGMENT)
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1599 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1600 SegmentAnnotation::Unserialize(*this, annotations[i]);
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1601 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1602 else
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1603 {
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1604 LOG(ERROR) << "Cannot unserialize unknown type of annotation: " << type;
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1605 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1606 }
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1607 }
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1608 };
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1609 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1610 #endif
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1611
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1612
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1613
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1614 std::string orthancUrl;
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1615 std::string instanceId;
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1616 int frameIndex = 0;
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1617
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
1618
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1619 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
1620 {
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1621 namespace po = boost::program_options;
1532
c7a37c3a0b8e print help in sdl samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1512
diff changeset
1622 po::options_description desc("Usage");
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1623
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1624 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
1625 ("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
1626 "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
1627
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1628 ("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
1629 "Base URL of the Orthanc instance")
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1630
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1631 ("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
1632 "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
1633
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1634 ("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
1635 "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
1636 ;
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1637
1532
c7a37c3a0b8e print help in sdl samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1512
diff changeset
1638 std::cout << desc << std::endl;
c7a37c3a0b8e print help in sdl samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1512
diff changeset
1639
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1640 std::cout << std::endl << "Keyboard shorcuts:" << std::endl
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1641 << " 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
1642 << " f\tToggle fullscreen display" << std::endl
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1643 << " 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
1644 << " q\tExit" << std::endl
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1645 << " 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
1646 << " s\tFit the viewpoint to the image" << std::endl
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1647 << " 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
1648 << std::endl << "Mouse buttons:" << std::endl
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1649 << " left \tChange windowing, or edit annotation" << std::endl
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1650 << " center\tMove the viewpoint, or edit annotation" << std::endl
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1651 << " 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
1652 << std::endl;
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1653
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1654 po::variables_map vm;
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1655 try
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1656 {
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1657 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
1658 po::notify(vm);
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1659 }
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1660 catch (std::exception& e)
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1661 {
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1662 std::cerr << "Please check your command line options! (\"" << e.what() << "\")" << std::endl;
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1663 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1664
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
1665 if (vm.count("loglevel") > 0)
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1666 {
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
1667 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
1668 OrthancStoneHelpers::SetLogLevel(logLevel);
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1669 }
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1670
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1671 if (vm.count("orthanc") > 0)
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1672 {
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1673 // maybe check URL validity here
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1674 orthancUrl = vm["orthanc"].as<std::string>();
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1675 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1676
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1677 if (vm.count("instance") > 0)
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1678 {
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1679 instanceId = vm["instance"].as<std::string>();
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1680 }
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1681
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1682 if (vm.count("frame_index") > 0)
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1683 {
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1684 frameIndex = vm["frame_index"].as<int>();
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1685 }
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1686 }
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1687
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1688
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1689 enum ActiveTool
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1690 {
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1691 ActiveTool_None,
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1692 ActiveTool_Line,
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1693 ActiveTool_Angle
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1694 };
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1695
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1696
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1697 /**
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1698 * IMPORTANT: The full arguments to "main()" are needed for SDL on
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1699 * Windows. Otherwise, one gets the linking error "undefined reference
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1700 * to `SDL_main'". https://wiki.libsdl.org/FAQWindows
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1701 **/
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1702 int main(int argc, char* argv[])
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1703 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1704 try
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1705 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1706 OrthancStone::StoneInitialize();
1591
5887a4f8594b moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1576
diff changeset
1707 OrthancStone::SdlWindow::GlobalInitialize();
5887a4f8594b moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1576
diff changeset
1708
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1709 ProcessOptions(argc, argv);
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1710
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1711 //Orthanc::Logging::EnableInfoLevel(true);
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1712 //Orthanc::Logging::EnableTraceLevel(true);
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1713
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1714 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1715
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1716 #if 1
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1717 boost::shared_ptr<OrthancStone::SdlViewport> viewport =
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1718 OrthancStone::SdlOpenGLViewport::Create("Stone of Orthanc", 800, 600);
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1719 #else
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1720 boost::shared_ptr<OrthancStone::SdlViewport> viewport =
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1721 OrthancStone::SdlCairoViewport::Create("Stone of Orthanc", 800, 600);
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1722 #endif
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1723
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1724 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
1725
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1726 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
1727
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
1728 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
1729 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
1730 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
1731
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1732 context.StartOracle();
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1733
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1734 {
1789
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 std::string font;
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1737 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
1738
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1739 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
1740 lock->GetCompositor().SetFont(0, font, 16, Orthanc::Encoding_Latin1);
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1741 //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
1742 }
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1743
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1744 ActiveTool activeTool = ActiveTool_None;
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1745
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1746 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
1747 bool lineMeasureFirst = true;
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1748 lineMeasureTool->Disable();
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1749
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1750 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
1751 bool angleMeasureFirst = true;
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1752 angleMeasureTool->Disable();
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1753
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1754 OrthancStone::AnnotationsOverlay overlay(10);
1798
41f3872bd7d2 create angle tool and delete measure tool
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1797
diff changeset
1755 overlay.SetActiveTool(OrthancStone::AnnotationsOverlay::Tool_Angle);
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1756
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1757 {
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1758 Json::Value v;
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1759 overlay.Serialize(v);
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1760 std::cout << v.toStyledString() << std::endl;
1800
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1761 overlay.Clear();
2c0497d61a5d unserialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1799
diff changeset
1762 overlay.Unserialize(v);
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1763 }
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1764
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1765 boost::shared_ptr<SdlSimpleViewerApplication> application(
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1766 SdlSimpleViewerApplication::Create(context, viewport));
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1767
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1768 OrthancStone::DicomSource source;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1769
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1770 application->LoadOrthancFrame(source, instanceId, frameIndex);
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1771
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1772 OrthancStone::DefaultViewportInteractor interactor;
1535
301571299212 DefaultViewportInteractor::SetWindowingLayer()
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1532
diff changeset
1773 interactor.SetWindowingLayer(0);
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1774
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1775 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1776 int scancodeCount = 0;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1777 const uint8_t* keyboardState = SDL_GetKeyboardState(&scancodeCount);
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1778
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1779 bool stop = false;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1780 while (!stop)
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1781 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1782 bool paint = false;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1783 SDL_Event event;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1784 while (SDL_PollEvent(&event))
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1785 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1786 if (event.type == SDL_QUIT)
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1787 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1788 stop = true;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1789 break;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1790 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1791 else if (viewport->IsRefreshEvent(event))
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1792 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1793 paint = true;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1794 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1795 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
1796 (event.window.event == SDL_WINDOWEVENT_RESIZED ||
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1797 event.window.event == SDL_WINDOWEVENT_SIZE_CHANGED))
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1798 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1799 viewport->UpdateSize(event.window.data1, event.window.data2);
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1800 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1801 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
1802 (event.window.event == SDL_WINDOWEVENT_SHOWN ||
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1803 event.window.event == SDL_WINDOWEVENT_EXPOSED))
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1804 {
1576
92fca2b3ba3d sanitizing the handling of canvas size
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1560
diff changeset
1805 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
1806 lock->RefreshCanvasSize();
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1807 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1808 else if (event.type == SDL_KEYDOWN &&
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1809 event.key.repeat == 0 /* Ignore key bounce */)
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1810 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1811 switch (event.key.keysym.sym)
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1812 {
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1813 case SDLK_f:
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1814 viewport->ToggleMaximize();
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1815 break;
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1816
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1817 case SDLK_s:
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1818 application->FitContent();
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1819 break;
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1820
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1821 case SDLK_q:
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1822 stop = true;
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1823 break;
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1824
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1825 case SDLK_u:
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1826 {
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1827 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
1828 if (lock->GetController().CanUndo())
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1829 {
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1830 lock->GetController().Undo();
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1831 }
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1832 break;
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1833 }
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1834
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1835 case SDLK_r:
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1836 {
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1837 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
1838 if (lock->GetController().CanRedo())
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1839 {
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1840 lock->GetController().Redo();
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1841 }
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1842 break;
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1843 }
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1844
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1845 case SDLK_l:
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1846 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
1847 {
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1848 lineMeasureTool->Disable();
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1849 activeTool = ActiveTool_None;
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1850 }
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1851 else
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1852 {
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1853 if (lineMeasureFirst)
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1854 {
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1855 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
1856 OrthancStone::Extent2D extent;
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1857 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
1858 if (!extent.IsEmpty())
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1859 {
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1860 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
1861 lineMeasureTool->Set(p, p);
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1862 }
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1863 lineMeasureFirst = false;
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
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1866 lineMeasureTool->Enable();
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1867 angleMeasureTool->Disable();
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1868 activeTool = ActiveTool_Line;
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1869 }
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1870 break;
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1871
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1872 case SDLK_a:
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1873 if (activeTool == ActiveTool_Angle)
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1874 {
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1875 angleMeasureTool->Disable();
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1876 activeTool = ActiveTool_None;
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1877 }
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1878 else
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1879 {
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1880 if (angleMeasureFirst)
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1881 {
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1882 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
1883 OrthancStone::Extent2D extent;
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1884 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
1885 if (!extent.IsEmpty())
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1886 {
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1887 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
1888 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
1889 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
1890 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
1891 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
1892 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
1893 angleMeasureTool->SetSide1End(p1);
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1894 angleMeasureTool->SetCenter(p2);
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1895 angleMeasureTool->SetSide2End(p3);
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1896 }
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1897 angleMeasureFirst = false;
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1898 }
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1899
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1900 lineMeasureTool->Disable();
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1901 angleMeasureTool->Enable();
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1902 activeTool = ActiveTool_Angle;
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1903 }
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1904 break;
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1905
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1906 default:
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1907 break;
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1908 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1909 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1910 else if (event.type == SDL_MOUSEBUTTONDOWN ||
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1911 event.type == SDL_MOUSEMOTION ||
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1912 event.type == SDL_MOUSEBUTTONUP)
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1913 {
1507
169adf9090a6 replacing deprecated std::auto_ptr by std::unique_ptr
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1458
diff changeset
1914 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock());
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1915 if (lock->HasCompositor())
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1916 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1917 OrthancStone::PointerEvent p;
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1918 OrthancStoneHelpers::GetPointerEvent(p, lock->GetCompositor(),
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
1919 event, keyboardState, scancodeCount);
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1920
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1921 switch (event.type)
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1922 {
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1923 case SDL_MOUSEBUTTONDOWN:
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1924 {
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1925 boost::shared_ptr<OrthancStone::IFlexiblePointerTracker> t;
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1926
1799
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1927 if (p.GetMouseButton() == OrthancStone::MouseButton_Left)
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1928 {
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1929 t.reset(overlay.CreateTracker(p.GetMainPosition(), lock->GetController().GetScene()));
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1930 }
1125793d82d3 serialization of annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1798
diff changeset
1931
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1932 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
1933 {
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1934 switch (activeTool)
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1935 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1936 case ActiveTool_Angle:
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1937 t = angleMeasureTool->CreateEditionTracker(p);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1938 break;
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1939
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1940 case ActiveTool_Line:
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1941 t = lineMeasureTool->CreateEditionTracker(p);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1942 break;
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1943
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1944 case ActiveTool_None:
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1945 break;
1790
b325761e0bd3 angle measure and undo/redo in sdl simple viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1789
diff changeset
1946
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1947 default:
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1948 throw Orthanc::OrthancException(Orthanc::ErrorCode_NotImplemented);
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1949 }
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1950 }
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1951
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1952 if (t.get() != NULL)
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1953 {
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1954 lock->GetController().AcquireActiveTracker(t);
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1955 }
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1956 else
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1957 {
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1958 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
1959 lock->GetCompositor().GetCanvasWidth(),
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1960 lock->GetCompositor().GetCanvasHeight());
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1961 }
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1962 lock->Invalidate();
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1963 break;
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1964 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1965
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1966 case SDL_MOUSEMOTION:
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1967 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
1968 {
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1969 lock->Invalidate();
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1970 if (overlay.ClearHover())
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1971 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1972 paint = true;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1973 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1974 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1975 else
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1976 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1977 if (overlay.SetMouseHover(p.GetMainPosition(), lock->GetController().GetScene()))
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1978 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1979 paint = true;
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1980 }
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1981 }
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1982 break;
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1983
1789
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1984 case SDL_MOUSEBUTTONUP:
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1985 lock->GetController().HandleMouseRelease(p);
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1986 lock->Invalidate();
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1987 break;
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1988
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1989 default:
462d7a0e064e added line measures to sdl single frame viewer sample
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1739
diff changeset
1990 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError);
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1991 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1992 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1993 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1994 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1995
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1996 if (paint)
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
1997 {
1796
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1998 {
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
1999 std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport->Lock());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
2000 overlay.Render(lock->GetController().GetScene());
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
2001 }
20a0aba0ede5 creation of AnnotationsOverlay
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1790
diff changeset
2002
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2003 viewport->Paint();
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2004 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2005
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2006 // Small delay to avoid using 100% of CPU
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2007 SDL_Delay(1);
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2008 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2009 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2010 context.StopOracle();
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2011 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2012 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2013
1591
5887a4f8594b moving platform-specific files out of the "OrthancStone" folder
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1576
diff changeset
2014 OrthancStone::SdlWindow::GlobalFinalize();
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2015 OrthancStone::StoneFinalize();
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2016 return 0;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2017 }
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
2018 catch (Orthanc::OrthancException& e)
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2019 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2020 LOG(ERROR) << "OrthancException: " << e.What();
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2021 return -1;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2022 }
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
2023 catch (OrthancStone::StoneException& e)
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2024 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2025 LOG(ERROR) << "StoneException: " << e.What();
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2026 return -1;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2027 }
1382
9d138883be66 Proper command-line parameter management for SDL sample
Benjamin Golinvaux <bgo@osimis.io>
parents: 1368
diff changeset
2028 catch (std::runtime_error& e)
1368
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2029 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2030 LOG(ERROR) << "Runtime error: " << e.what();
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2031 return -1;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2032 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2033 catch (...)
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2034 {
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2035 LOG(ERROR) << "Native exception";
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2036 return -1;
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2037 }
33da5d02885f SdlSimpleViewer rename
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff changeset
2038 }