| 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 #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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 |
| OLD | NEW |