Mercurial > hg > orthanc-stone
annotate Framework/Scene2D/PanSceneTracker.cpp @ 1140:6333e6f7248e broker
fix cache
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Thu, 07 Nov 2019 16:53:15 +0100 |
parents | 13e078adfb94 |
children | 2d8ab34c8c91 |
rev | line source |
---|---|
596 | 1 /** |
2 * Stone of Orthanc | |
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics | |
4 * Department, University Hospital of Liege, Belgium | |
5 * Copyright (C) 2017-2019 Osimis S.A., Belgium | |
6 * | |
7 * This program is free software: you can redistribute it and/or | |
8 * modify it under the terms of the GNU Affero General Public License | |
9 * as published by the Free Software Foundation, either version 3 of | |
10 * the License, or (at your option) any later version. | |
11 * | |
12 * This program is distributed in the hope that it will be useful, but | |
13 * WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
15 * Affero General Public License for more details. | |
16 * | |
17 * You should have received a copy of the GNU Affero General Public License | |
18 * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
19 **/ | |
20 | |
21 | |
22 #include "PanSceneTracker.h" | |
736
c0fcb2757b0a
enforce relative includes
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
700
diff
changeset
|
23 #include "../Scene2DViewport/ViewportController.h" |
596 | 24 |
25 namespace OrthancStone | |
26 { | |
818
e42b491f1fb2
Removed typedefs to shared_ptr by making them explicit. Removed using namespace
Benjamin Golinvaux <bgo@osimis.io>
parents:
736
diff
changeset
|
27 PanSceneTracker::PanSceneTracker(boost::weak_ptr<ViewportController> controllerW, |
700
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
28 const PointerEvent& event) |
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
29 : OneGesturePointerTracker(controllerW) |
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
30 , originalSceneToCanvas_(GetController()->GetSceneToCanvasTransform()) |
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
31 , originalCanvasToScene_(GetController()->GetCanvasToSceneTransform()) |
596 | 32 { |
33 pivot_ = event.GetMainPosition().Apply(originalCanvasToScene_); | |
34 } | |
35 | |
36 | |
700
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
37 void PanSceneTracker::PointerMove(const PointerEvent& event) |
596 | 38 { |
39 ScenePoint2D p = event.GetMainPosition().Apply(originalCanvasToScene_); | |
959
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
40 |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
41 // The controller is a weak pointer. It could be deleted when the |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
42 // tracker is still alive (for instance, because of a lost WebGL |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
43 // context) |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
44 if(GetController().get() != NULL) |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
45 { |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
46 GetController()->SetSceneToCanvasTransform( |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
47 AffineTransform2D::Combine( |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
48 originalSceneToCanvas_, |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
49 AffineTransform2D::CreateOffset(p.GetX() - pivot_.GetX(), |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
50 p.GetY() - pivot_.GetY()))); |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
51 } |
596 | 52 } |
700
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
53 |
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
54 void PanSceneTracker::Cancel() |
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
55 { |
959
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
56 if(GetController().get() != NULL) |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
57 { |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
58 GetController()->SetSceneToCanvasTransform(originalSceneToCanvas_); |
13e078adfb94
Better error log in fetch failure callback +
Benjamin Golinvaux <bgo@osimis.io>
parents:
818
diff
changeset
|
59 } |
700
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
60 } |
059e1fd05fd6
Introduced the ViewportController that sits between the application and the
Benjamin Golinvaux <bgo@osimis.io>
parents:
596
diff
changeset
|
61 |
596 | 62 } |