Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(70)

Side by Side Diff: content/renderer/input/input_handler_manager.cc

Issue 1620053002: sync compositor: Merge input path with chrome (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: review Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 #include "content/renderer/input/input_handler_manager.h" 5 #include "content/renderer/input/input_handler_manager.h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/location.h" 10 #include "base/location.h"
(...skipping 30 matching lines...) Expand all
41 } 41 }
42 NOTREACHED(); 42 NOTREACHED();
43 return INPUT_EVENT_ACK_STATE_UNKNOWN; 43 return INPUT_EVENT_ACK_STATE_UNKNOWN;
44 } 44 }
45 45
46 } // namespace 46 } // namespace
47 47
48 InputHandlerManager::InputHandlerManager( 48 InputHandlerManager::InputHandlerManager(
49 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, 49 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner,
50 InputHandlerManagerClient* client, 50 InputHandlerManagerClient* client,
51 SynchronousInputHandlerProxyClient* sync_handler_client,
51 scheduler::RendererScheduler* renderer_scheduler) 52 scheduler::RendererScheduler* renderer_scheduler)
52 : task_runner_(task_runner), 53 : task_runner_(task_runner),
53 client_(client), 54 client_(client),
55 synchronous_handler_proxy_client_(sync_handler_client),
54 renderer_scheduler_(renderer_scheduler) { 56 renderer_scheduler_(renderer_scheduler) {
55 DCHECK(client_); 57 DCHECK(client_);
56 client_->SetBoundHandler(base::Bind(&InputHandlerManager::HandleInputEvent, 58 client_->SetBoundHandler(base::Bind(&InputHandlerManager::HandleInputEvent,
57 base::Unretained(this))); 59 base::Unretained(this)));
58 } 60 }
59 61
60 InputHandlerManager::~InputHandlerManager() { 62 InputHandlerManager::~InputHandlerManager() {
61 client_->SetBoundHandler(InputHandlerManagerClient::Handler()); 63 client_->SetBoundHandler(InputHandlerManagerClient::Handler());
62 } 64 }
63 65
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
98 // The same handler may be registered for a route multiple times. 100 // The same handler may be registered for a route multiple times.
99 if (input_handlers_.count(routing_id) != 0) 101 if (input_handlers_.count(routing_id) != 0)
100 return; 102 return;
101 103
102 TRACE_EVENT1("input", 104 TRACE_EVENT1("input",
103 "InputHandlerManager::AddInputHandlerOnCompositorThread", 105 "InputHandlerManager::AddInputHandlerOnCompositorThread",
104 "result", "AddingRoute"); 106 "result", "AddingRoute");
105 scoped_ptr<InputHandlerWrapper> wrapper(new InputHandlerWrapper( 107 scoped_ptr<InputHandlerWrapper> wrapper(new InputHandlerWrapper(
106 this, routing_id, main_task_runner, input_handler, render_view_impl, 108 this, routing_id, main_task_runner, input_handler, render_view_impl,
107 enable_smooth_scrolling, enable_wheel_gestures)); 109 enable_smooth_scrolling, enable_wheel_gestures));
108 client_->DidAddInputHandler(routing_id, wrapper->input_handler_proxy()); 110 client_->DidAddInputHandler(routing_id);
111 if (synchronous_handler_proxy_client_) {
112 synchronous_handler_proxy_client_->DidAddSynchronousHandlerProxy(
113 routing_id, wrapper->input_handler_proxy());
114 }
109 input_handlers_.add(routing_id, std::move(wrapper)); 115 input_handlers_.add(routing_id, std::move(wrapper));
110 } 116 }
111 117
112 void InputHandlerManager::RemoveInputHandler(int routing_id) { 118 void InputHandlerManager::RemoveInputHandler(int routing_id) {
113 DCHECK(task_runner_->BelongsToCurrentThread()); 119 DCHECK(task_runner_->BelongsToCurrentThread());
114 DCHECK(input_handlers_.contains(routing_id)); 120 DCHECK(input_handlers_.contains(routing_id));
115 121
116 TRACE_EVENT0("input", "InputHandlerManager::RemoveInputHandler"); 122 TRACE_EVENT0("input", "InputHandlerManager::RemoveInputHandler");
117 123
118 client_->DidRemoveInputHandler(routing_id); 124 client_->DidRemoveInputHandler(routing_id);
125 if (synchronous_handler_proxy_client_) {
126 synchronous_handler_proxy_client_->DidRemoveSynchronousHandlerProxy(
127 routing_id);
128 }
119 input_handlers_.erase(routing_id); 129 input_handlers_.erase(routing_id);
120 } 130 }
121 131
122 void InputHandlerManager::ObserveWheelEventAndResultOnMainThread( 132 void InputHandlerManager::ObserveWheelEventAndResultOnMainThread(
123 int routing_id, 133 int routing_id,
124 const blink::WebMouseWheelEvent& wheel_event, 134 const blink::WebMouseWheelEvent& wheel_event,
125 const cc::InputHandlerScrollResult& scroll_result) { 135 const cc::InputHandlerScrollResult& scroll_result) {
126 task_runner_->PostTask( 136 task_runner_->PostTask(
127 FROM_HERE, 137 FROM_HERE,
128 base::Bind( 138 base::Bind(
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after
210 220
211 void InputHandlerManager::DidStopFlinging(int routing_id) { 221 void InputHandlerManager::DidStopFlinging(int routing_id) {
212 client_->DidStopFlinging(routing_id); 222 client_->DidStopFlinging(routing_id);
213 } 223 }
214 224
215 void InputHandlerManager::DidAnimateForInput() { 225 void InputHandlerManager::DidAnimateForInput() {
216 renderer_scheduler_->DidAnimateForInputOnCompositorThread(); 226 renderer_scheduler_->DidAnimateForInputOnCompositorThread();
217 } 227 }
218 228
219 } // namespace content 229 } // namespace content
OLDNEW
« no previous file with comments | « content/renderer/input/input_handler_manager.h ('k') | content/renderer/input/input_handler_manager_client.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698