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 3 // found in the LICENSE file. 4 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_INPUT_INPUT_ROUTER_H_ 6 #define CONTENT_BROWSER_RENDERER_HOST_INPUT_INPUT_ROUTER_H_ 7 8 #include "base/basictypes.h" 9 #include "content/browser/renderer_host/event_with_latency_info.h" 10 #include "content/common/input/input_event_ack_state.h" 11 #include "content/public/browser/native_web_keyboard_event.h" 12 #include "ipc/ipc_listener.h" 13 #include "third_party/WebKit/public/web/WebInputEvent.h" 14 15 namespace content { 16 17 class InputRouterClient; 18 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. 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. 23 class InputRouter : public IPC::Listener { 24 public: ~InputRouter()25 virtual ~InputRouter() {} 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 32 // only for event types not associated with a WebInputEvent. Returns true on 33 // success and false otherwise. 34 virtual bool SendInput(scoped_ptr<IPC::Message> message) = 0; 35 36 // WebInputEvents 37 virtual void SendMouseEvent( 38 const MouseEventWithLatencyInfo& mouse_event) = 0; 39 virtual void SendWheelEvent( 40 const MouseWheelEventWithLatencyInfo& wheel_event) = 0; 41 virtual void SendKeyboardEvent( 42 const NativeWebKeyboardEvent& key_event, 43 const ui::LatencyInfo& latency_info, 44 bool is_shortcut) = 0; 45 virtual void SendGestureEvent( 46 const GestureEventWithLatencyInfo& gesture_event) = 0; 47 virtual void SendTouchEvent( 48 const TouchEventWithLatencyInfo& touch_event) = 0; 49 50 // Returns the oldest queued or in-flight keyboard event sent to the router. 51 virtual const NativeWebKeyboardEvent* GetLastKeyboardEvent() const = 0; 52 53 // Returns |true| if the caller should immediately forward touch events to the 54 // router. When |false|, the caller can forego sending touch events, and 55 // instead consume them directly. 56 virtual bool ShouldForwardTouchEvent() const = 0; 57 58 // Allow the router to make more informed input handling decisions based on 59 // the current view. 60 enum ViewFlags { 61 VIEW_FLAGS_NONE = 0, 62 FIXED_PAGE_SCALE = 1 << 0, 63 MOBILE_VIEWPORT = 1 << 1 64 }; 65 virtual void OnViewUpdated(int view_flags) = 0; 66 67 virtual bool HasPendingEvents() const = 0; 68 }; 69 70 } // namespace content 71 72 #endif // CONTENT_BROWSER_RENDERER_HOST_INPUT_INPUT_ROUTER_H_ 73