OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CONTENT_BROWSER_RENDERER_HOST_INPUT_INPUT_ROUTER_H_ | 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_INPUT_INPUT_ROUTER_H_ |
6 #define CONTENT_BROWSER_RENDERER_HOST_INPUT_INPUT_ROUTER_H_ | 6 #define CONTENT_BROWSER_RENDERER_HOST_INPUT_INPUT_ROUTER_H_ |
7 | 7 |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "content/browser/renderer_host/event_with_latency_info.h" | 9 #include "content/browser/renderer_host/event_with_latency_info.h" |
10 #include "content/common/input/input_event_ack_state.h" | 10 #include "content/common/input/input_event_ack_state.h" |
11 #include "content/public/browser/native_web_keyboard_event.h" | 11 #include "content/public/browser/native_web_keyboard_event.h" |
12 #include "ipc/ipc_listener.h" | 12 #include "ipc/ipc_listener.h" |
13 #include "third_party/WebKit/public/web/WebInputEvent.h" | 13 #include "third_party/WebKit/public/web/WebInputEvent.h" |
14 | 14 |
15 namespace content { | 15 namespace content { |
16 | 16 |
17 class InputRouterClient; | 17 class InputRouterClient; |
18 | 18 |
19 // The InputRouter allows the embedder to customize how input events are | 19 // The InputRouter allows the embedder to customize how input events are |
20 // sent to the renderer, and how responses are dispatched to the browser. | 20 // sent to the renderer, and how responses are dispatched to the browser. |
21 // While the router should respect the relative order in which events are | 21 // While the router should respect the relative order in which events are |
22 // received, it is free to customize when those events are dispatched. | 22 // received, it is free to customize when those events are dispatched. |
23 class InputRouter : public IPC::Listener { | 23 class InputRouter : public IPC::Listener { |
24 public: | 24 public: |
25 ~InputRouter() override {} | 25 ~InputRouter() override {} |
26 | 26 |
27 // Should be called only in response to |SetNeedsFlush| requests made via | |
28 // the |InputRouterClient|. | |
29 virtual void Flush() = 0; | |
30 | |
31 // Send and take ownership of the the given InputMsg_*. This should be used | 27 // Send and take ownership of the the given InputMsg_*. This should be used |
32 // only for event types not associated with a WebInputEvent. Returns true on | 28 // only for event types not associated with a WebInputEvent. Returns true on |
33 // success and false otherwise. | 29 // success and false otherwise. |
34 virtual bool SendInput(scoped_ptr<IPC::Message> message) = 0; | 30 virtual bool SendInput(scoped_ptr<IPC::Message> message) = 0; |
35 | 31 |
36 // WebInputEvents | 32 // WebInputEvents |
37 virtual void SendMouseEvent( | 33 virtual void SendMouseEvent( |
38 const MouseEventWithLatencyInfo& mouse_event) = 0; | 34 const MouseEventWithLatencyInfo& mouse_event) = 0; |
39 virtual void SendWheelEvent( | 35 virtual void SendWheelEvent( |
40 const MouseWheelEventWithLatencyInfo& wheel_event) = 0; | 36 const MouseWheelEventWithLatencyInfo& wheel_event) = 0; |
(...skipping 11 matching lines...) Expand all Loading... |
52 | 48 |
53 // Allow the router to make more informed input handling decisions based on | 49 // Allow the router to make more informed input handling decisions based on |
54 // the current view. | 50 // the current view. |
55 enum ViewFlags { | 51 enum ViewFlags { |
56 VIEW_FLAGS_NONE = 0, | 52 VIEW_FLAGS_NONE = 0, |
57 FIXED_PAGE_SCALE = 1 << 0, | 53 FIXED_PAGE_SCALE = 1 << 0, |
58 MOBILE_VIEWPORT = 1 << 1 | 54 MOBILE_VIEWPORT = 1 << 1 |
59 }; | 55 }; |
60 virtual void OnViewUpdated(int view_flags) = 0; | 56 virtual void OnViewUpdated(int view_flags) = 0; |
61 | 57 |
| 58 // Request a notification from the input router when all events have been |
| 59 // fully dispatched and there are no longer any pending events. |
| 60 // Note: This may trigger a synchronous notification if the router is empty. |
| 61 virtual void RequestNotificationWhenFlushed() = 0; |
| 62 |
| 63 // Whether there are any events pending dispatch to or ack from the renderer. |
62 virtual bool HasPendingEvents() const = 0; | 64 virtual bool HasPendingEvents() const = 0; |
63 }; | 65 }; |
64 | 66 |
65 } // namespace content | 67 } // namespace content |
66 | 68 |
67 #endif // CONTENT_BROWSER_RENDERER_HOST_INPUT_INPUT_ROUTER_H_ | 69 #endif // CONTENT_BROWSER_RENDERER_HOST_INPUT_INPUT_ROUTER_H_ |
OLD | NEW |