OLD | NEW |
| (Empty) |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef UI_VIEWS_TOUCH_EVENT_WATCHER_H_ | |
6 #define UI_VIEWS_TOUCH_EVENT_WATCHER_H_ | |
7 | |
8 #include "base/macros.h" | |
9 #include "ui/views/views_export.h" | |
10 | |
11 namespace gfx { | |
12 class Point; | |
13 } | |
14 | |
15 namespace ui { | |
16 class LocatedEvent; | |
17 } | |
18 | |
19 namespace views { | |
20 class Widget; | |
21 | |
22 // An interface for read-only observation of touch events (in particular, the | |
23 // events cannot be marked as handled). Only touch pointer kind are supported. | |
24 // The |target| is the top-level widget that will receive the event, if any. | |
25 // NOTE: On mus this allows observation of events outside of windows owned | |
26 // by the current process, in which case the |target| will be null. On mus | |
27 // event.target() is always null. | |
28 class VIEWS_EXPORT TouchEventWatcher { | |
29 public: | |
30 TouchEventWatcher() {} | |
31 virtual void OnTouchEventObserved(const ui::LocatedEvent& event, | |
32 Widget* target) = 0; | |
33 | |
34 protected: | |
35 virtual ~TouchEventWatcher() {} | |
36 | |
37 private: | |
38 DISALLOW_COPY_AND_ASSIGN(TouchEventWatcher); | |
39 }; | |
40 | |
41 } // namespace views | |
42 | |
43 #endif // UI_VIEWS_TOUCH_EVENT_WATCHER_H_ | |
OLD | NEW |