Mercurial > hg > orthanc-stone
annotate OrthancStone/Sources/Scene2D/AnnotationsSceneLayer.h @ 1989:e8b9a2ba1df1
Added left/right rotation buttons
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Mon, 31 Oct 2022 20:59:59 +0100 |
parents | a595776232bb |
children | 1fa3f484008e |
rev | line source |
---|---|
1804 | 1 /** |
2 * Stone of Orthanc | |
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics | |
4 * Department, University Hospital of Liege, Belgium | |
1871
7053b8a0aaec
upgrade to year 2022
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1870
diff
changeset
|
5 * Copyright (C) 2017-2022 Osimis S.A., Belgium |
7053b8a0aaec
upgrade to year 2022
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1870
diff
changeset
|
6 * Copyright (C) 2021-2022 Sebastien Jodogne, ICTEAM UCLouvain, Belgium |
1804 | 7 * |
8 * This program is free software: you can redistribute it and/or | |
9 * modify it under the terms of the GNU Lesser General Public License | |
10 * as published by the Free Software Foundation, either version 3 of | |
11 * the License, or (at your option) any later version. | |
12 * | |
13 * This program is distributed in the hope that it will be useful, but | |
14 * WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
16 * Lesser General Public License for more details. | |
17 * | |
18 * You should have received a copy of the GNU Lesser General Public | |
19 * License along with this program. If not, see | |
20 * <http://www.gnu.org/licenses/>. | |
21 **/ | |
22 | |
23 | |
24 #include "../Messages/IObservable.h" | |
25 #include "Scene2D.h" | |
26 #include "../Scene2DViewport/IFlexiblePointerTracker.h" | |
27 | |
28 namespace OrthancStone | |
29 { | |
30 class AnnotationsSceneLayer : public IObservable | |
31 { | |
32 public: | |
33 ORTHANC_STONE_DEFINE_ORIGIN_MESSAGE(__FILE__, __LINE__, AnnotationAddedMessage, AnnotationsSceneLayer); | |
34 ORTHANC_STONE_DEFINE_ORIGIN_MESSAGE(__FILE__, __LINE__, AnnotationRemovedMessage, AnnotationsSceneLayer); | |
1809
79a5838739a6
starting the integration of AnnotationsSceneLayer into Stone Web viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1806
diff
changeset
|
35 ORTHANC_STONE_DEFINE_ORIGIN_MESSAGE(__FILE__, __LINE__, AnnotationChangedMessage, AnnotationsSceneLayer); |
1804 | 36 |
37 enum Tool | |
38 { | |
39 Tool_Edit, | |
40 Tool_None, | |
41 Tool_Segment, | |
42 Tool_Angle, | |
43 Tool_Circle, | |
1975
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
44 Tool_Remove, |
1982
ba45e1b0812a
preparing interfaces for rectangle probe, ellipse probe and text annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1978
diff
changeset
|
45 Tool_PixelProbe, |
ba45e1b0812a
preparing interfaces for rectangle probe, ellipse probe and text annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1978
diff
changeset
|
46 Tool_RectangleProbe, |
ba45e1b0812a
preparing interfaces for rectangle probe, ellipse probe and text annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1978
diff
changeset
|
47 Tool_EllipseProbe, |
ba45e1b0812a
preparing interfaces for rectangle probe, ellipse probe and text annotations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1978
diff
changeset
|
48 Tool_TextAnnotation |
1804 | 49 }; |
1821
36430d73e36c
introducing measure units in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1817
diff
changeset
|
50 |
1804 | 51 private: |
52 class GeometricPrimitive; | |
53 class Handle; | |
54 class Segment; | |
55 class Circle; | |
56 class Arc; | |
57 class Text; | |
1987
a595776232bb
added ellipse probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1983
diff
changeset
|
58 class Ellipse; |
1804 | 59 |
60 class Annotation; | |
1978
95449b0e064a
pixel probe is working
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1977
diff
changeset
|
61 class ProbingAnnotation; |
1975
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
62 class PixelProbeAnnotation; |
1804 | 63 class SegmentAnnotation; |
64 class AngleAnnotation; | |
65 class CircleAnnotation; | |
1983
20fa913272b7
drawing rectangle probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1982
diff
changeset
|
66 class RectangleProbeAnnotation; |
1987
a595776232bb
added ellipse probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1983
diff
changeset
|
67 class EllipseProbeAnnotation; |
1804 | 68 |
69 class EditPrimitiveTracker; | |
1983
20fa913272b7
drawing rectangle probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1982
diff
changeset
|
70 class CreateTwoHandlesTracker; |
1804 | 71 class CreateAngleTracker; |
1975
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
72 class CreatePixelProbeTracker; |
1809
79a5838739a6
starting the integration of AnnotationsSceneLayer into Stone Web viewer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1806
diff
changeset
|
73 class RemoveTracker; |
1804 | 74 |
75 typedef std::set<GeometricPrimitive*> GeometricPrimitives; | |
76 typedef std::set<Annotation*> Annotations; | |
77 typedef std::set<size_t> SubLayers; | |
78 | |
79 Tool activeTool_; | |
80 size_t macroLayerIndex_; | |
81 size_t polylineSubLayer_; | |
82 GeometricPrimitives primitives_; | |
83 Annotations annotations_; | |
84 SubLayers subLayersToRemove_; | |
1821
36430d73e36c
introducing measure units in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1817
diff
changeset
|
85 Units units_; |
1975
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
86 int probedLayer_; |
1804 | 87 |
88 void AddAnnotation(Annotation* annotation); | |
89 | |
90 void DeleteAnnotation(Annotation* annotation); | |
91 | |
92 void DeletePrimitive(GeometricPrimitive* primitive); | |
93 | |
94 void TagSubLayerToRemove(size_t subLayerIndex); | |
95 | |
96 public: | |
1817 | 97 explicit AnnotationsSceneLayer(size_t macroLayerIndex); |
1804 | 98 |
99 ~AnnotationsSceneLayer() | |
100 { | |
101 Clear(); | |
102 } | |
103 | |
104 void Clear(); | |
105 | |
106 void SetActiveTool(Tool tool) | |
107 { | |
108 activeTool_ = tool; | |
109 } | |
110 | |
111 Tool GetActiveTool() const | |
112 { | |
113 return activeTool_; | |
114 } | |
115 | |
1821
36430d73e36c
introducing measure units in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1817
diff
changeset
|
116 void SetUnits(Units units); |
36430d73e36c
introducing measure units in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1817
diff
changeset
|
117 |
36430d73e36c
introducing measure units in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1817
diff
changeset
|
118 Units GetUnits() const |
36430d73e36c
introducing measure units in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1817
diff
changeset
|
119 { |
36430d73e36c
introducing measure units in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1817
diff
changeset
|
120 return units_; |
36430d73e36c
introducing measure units in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1817
diff
changeset
|
121 } |
36430d73e36c
introducing measure units in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1817
diff
changeset
|
122 |
1806
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
123 void AddSegmentAnnotation(const ScenePoint2D& p1, |
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
124 const ScenePoint2D& p2); |
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
125 |
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
126 void AddCircleAnnotation(const ScenePoint2D& p1, |
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
127 const ScenePoint2D& p2); |
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
128 |
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
129 void AddAngleAnnotation(const ScenePoint2D& p1, |
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
130 const ScenePoint2D& p2, |
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
131 const ScenePoint2D& p3); |
0840a25c6d41
removed hard-coded test in AnnotationsSceneLayer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1804
diff
changeset
|
132 |
1804 | 133 void Render(Scene2D& scene); |
134 | |
135 bool ClearHover(); | |
136 | |
137 bool SetMouseHover(const ScenePoint2D& p /* expressed in canvas coordinates */, | |
138 const Scene2D& scene); | |
139 | |
140 IFlexiblePointerTracker* CreateTracker(const ScenePoint2D& p /* expressed in canvas coordinates */, | |
141 const Scene2D& scene); | |
142 | |
143 void Serialize(Json::Value& target) const; | |
144 | |
145 void Unserialize(const Json::Value& serialized); | |
1975
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
146 |
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
147 void SetProbedLayer(int layer) |
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
148 { |
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
149 probedLayer_ = layer; |
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
150 } |
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
151 |
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
152 int GetProbedLayer() const |
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
153 { |
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
154 return probedLayer_; |
5a434f5889f8
starting pixel probe
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1871
diff
changeset
|
155 } |
1804 | 156 }; |
157 } |