Mercurial > hg > orthanc-stone
annotate Samples/Common/MeasureTools.cpp @ 634:6a144a45b2d8
Converted C++11 code to C++03
author | Benjamin Golinvaux <bgo@osimis.io> |
---|---|
date | Thu, 09 May 2019 14:54:12 +0200 |
parents | 500c3f70b6c2 |
children | f939f449482c |
rev | line source |
---|---|
632
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
1 /** |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
2 * Stone of Orthanc |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
4 * Department, University Hospital of Liege, Belgium |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
5 * Copyright (C) 2017-2019 Osimis S.A., Belgium |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
6 * |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
7 * This program is free software: you can redistribute it and/or |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
8 * modify it under the terms of the GNU Affero General Public License |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
9 * as published by the Free Software Foundation, either version 3 of |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
10 * the License, or (at your option) any later version. |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
11 * |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
12 * This program is distributed in the hope that it will be useful, but |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
13 * WITHOUT ANY WARRANTY; without even the implied warranty of |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
15 * Affero General Public License for more details. |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
16 * |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
17 * You should have received a copy of the GNU Affero General Public License |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
18 * along with this program. If not, see <http://www.gnu.org/licenses/>. |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
19 **/ |
634
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
20 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
21 #include <Core/Logging.h> |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
22 #include "MeasureTools.h" |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
23 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
24 namespace OrthancStone |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
25 { |
632
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
26 void MeasureTool::Enable() |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
27 { |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
28 enabled_ = true; |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
29 RefreshScene(); |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
30 } |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
31 |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
32 void MeasureTool::Disable() |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
33 { |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
34 enabled_ = false; |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
35 RefreshScene(); |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
36 } |
634
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
37 |
632
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
38 LineMeasureTool::~LineMeasureTool() |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
39 { |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
40 // this measuring tool is a RABI for the corresponding visual layers |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
41 // stored in the 2D scene |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
42 Disable(); |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
43 RemoveFromScene(); |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
44 } |
634
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
45 |
632
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
46 void LineMeasureTool::RemoveFromScene() |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
47 { |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
48 if (layersCreated) |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
49 { |
634
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
50 assert(GetScene().HasLayer(polylineZIndex_)); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
51 assert(GetScene().HasLayer(textZIndex_)); |
632
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
52 GetScene().DeleteLayer(polylineZIndex_); |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
53 GetScene().DeleteLayer(textZIndex_); |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
54 } |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
55 } |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
56 |
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
57 |
634
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
58 void LineMeasureTool::SetStart(ScenePoint2D start) |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
59 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
60 start_ = start; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
61 RefreshScene(); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
62 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
63 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
64 void LineMeasureTool::SetEnd(ScenePoint2D end) |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
65 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
66 end_ = end; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
67 RefreshScene(); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
68 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
69 |
632
500c3f70b6c2
- Added a ClearAllChains method to PolylineSceneLayer --> revision must change
Benjamin Golinvaux <bgo@osimis.io>
parents:
diff
changeset
|
70 void LineMeasureTool::Set(ScenePoint2D start, ScenePoint2D end) |
634
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
71 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
72 start_ = start; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
73 end_ = end; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
74 RefreshScene(); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
75 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
76 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
77 PolylineSceneLayer* LineMeasureTool::GetPolylineLayer() |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
78 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
79 assert(GetScene().HasLayer(polylineZIndex_)); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
80 ISceneLayer* layer = &(GetScene().GetLayer(polylineZIndex_)); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
81 PolylineSceneLayer* concreteLayer = dynamic_cast<PolylineSceneLayer*>(layer); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
82 assert(concreteLayer != NULL); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
83 return concreteLayer; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
84 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
85 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
86 TextSceneLayer* LineMeasureTool::GetTextLayer() |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
87 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
88 assert(GetScene().HasLayer(textZIndex_)); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
89 ISceneLayer* layer = &(GetScene().GetLayer(textZIndex_)); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
90 TextSceneLayer* concreteLayer = dynamic_cast<TextSceneLayer*>(layer); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
91 assert(concreteLayer != NULL); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
92 return concreteLayer; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
93 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
94 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
95 void LineMeasureTool::RefreshScene() |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
96 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
97 if (IsEnabled()) |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
98 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
99 if (!layersCreated) |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
100 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
101 // Create the layers if need be |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
102 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
103 assert(textZIndex_ == -1); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
104 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
105 polylineZIndex_ = GetScene().GetMaxDepth() + 100; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
106 LOG(INFO) << "set polylineZIndex_ to: " << polylineZIndex_; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
107 std::auto_ptr<PolylineSceneLayer> layer(new PolylineSceneLayer()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
108 GetScene().SetLayer(polylineZIndex_, layer.release()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
109 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
110 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
111 textZIndex_ = GetScene().GetMaxDepth() + 100; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
112 LOG(INFO) << "set textZIndex_ to: " << textZIndex_; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
113 std::auto_ptr<TextSceneLayer> layer(new TextSceneLayer()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
114 GetScene().SetLayer(textZIndex_, layer.release()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
115 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
116 layersCreated = true; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
117 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
118 else |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
119 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
120 assert(GetScene().HasLayer(polylineZIndex_)); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
121 assert(GetScene().HasLayer(textZIndex_)); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
122 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
123 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
124 // Fill the polyline layer with the measurement line |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
125 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
126 PolylineSceneLayer* polylineLayer = GetPolylineLayer(); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
127 polylineLayer->ClearAllChains(); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
128 polylineLayer->SetColor(0, 223, 21); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
129 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
130 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
131 PolylineSceneLayer::Chain chain; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
132 chain.push_back(start_); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
133 chain.push_back(end_); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
134 polylineLayer->AddChain(chain, false); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
135 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
136 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
137 // handles |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
138 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
139 ScenePoint2D startC = start_.Apply(GetScene().GetSceneToCanvasTransform()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
140 double squareSize = 10.0; //TODO: take DPI into account |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
141 double startHandleLX = startC.GetX() - squareSize/2; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
142 double startHandleTY = startC.GetY() - squareSize / 2; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
143 double startHandleRX = startC.GetX() + squareSize / 2; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
144 double startHandleBY = startC.GetY() + squareSize / 2; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
145 ScenePoint2D startLTC(startHandleLX, startHandleTY); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
146 ScenePoint2D startRTC(startHandleRX, startHandleTY); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
147 ScenePoint2D startRBC(startHandleRX, startHandleBY); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
148 ScenePoint2D startLBC(startHandleLX, startHandleBY); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
149 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
150 ScenePoint2D startLT = startLTC.Apply(GetScene().GetCanvasToSceneTransform()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
151 ScenePoint2D startRT = startRTC.Apply(GetScene().GetCanvasToSceneTransform()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
152 ScenePoint2D startRB = startRBC.Apply(GetScene().GetCanvasToSceneTransform()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
153 ScenePoint2D startLB = startLBC.Apply(GetScene().GetCanvasToSceneTransform()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
154 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
155 PolylineSceneLayer::Chain chain; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
156 chain.push_back(startLT); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
157 chain.push_back(startRT); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
158 chain.push_back(startRB); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
159 chain.push_back(startLB); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
160 polylineLayer->AddChain(chain, true); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
161 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
162 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
163 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
164 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
165 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
166 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
167 // Set the text layer proporeties |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
168 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
169 TextSceneLayer* textLayer = GetTextLayer(); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
170 double deltaX = end_.GetX() - start_.GetX(); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
171 double deltaY = end_.GetY() - start_.GetY(); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
172 double squareDist = deltaX * deltaX + deltaY * deltaY; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
173 double dist = sqrt(squareDist); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
174 char buf[64]; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
175 sprintf(buf, "%0.02f units", dist); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
176 textLayer->SetText(buf); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
177 textLayer->SetColor(0, 223, 21); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
178 |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
179 // TODO: for now we simply position the text overlay at the middle |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
180 // of the measuring segment |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
181 double midX = 0.5*(end_.GetX() + start_.GetX()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
182 double midY = 0.5*(end_.GetY() + start_.GetY()); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
183 textLayer->SetPosition(midX, midY); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
184 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
185 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
186 else |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
187 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
188 if (layersCreated) |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
189 { |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
190 RemoveFromScene(); |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
191 layersCreated = false; |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
192 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
193 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
194 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
195 } |
6a144a45b2d8
Converted C++11 code to C++03
Benjamin Golinvaux <bgo@osimis.io>
parents:
632
diff
changeset
|
196 |