| 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 17 matching lines...) Expand all Loading... |
| 28 | 28 |
| 29 namespace { | 29 namespace { |
| 30 | 30 |
| 31 InputEventAckState InputEventDispositionToAck( | 31 InputEventAckState InputEventDispositionToAck( |
| 32 InputHandlerProxy::EventDisposition disposition) { | 32 InputHandlerProxy::EventDisposition disposition) { |
| 33 switch (disposition) { | 33 switch (disposition) { |
| 34 case InputHandlerProxy::DID_HANDLE: | 34 case InputHandlerProxy::DID_HANDLE: |
| 35 return INPUT_EVENT_ACK_STATE_CONSUMED; | 35 return INPUT_EVENT_ACK_STATE_CONSUMED; |
| 36 case InputHandlerProxy::DID_NOT_HANDLE: | 36 case InputHandlerProxy::DID_NOT_HANDLE: |
| 37 return INPUT_EVENT_ACK_STATE_NOT_CONSUMED; | 37 return INPUT_EVENT_ACK_STATE_NOT_CONSUMED; |
| 38 case InputHandlerProxy::DID_NOT_HANDLE_NON_BLOCKING: |
| 39 return INPUT_EVENT_ACK_STATE_NOT_CONSUMED_NON_BLOCKING; |
| 38 case InputHandlerProxy::DROP_EVENT: | 40 case InputHandlerProxy::DROP_EVENT: |
| 39 return INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS; | 41 return INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS; |
| 40 case InputHandlerProxy::DID_HANDLE_NON_BLOCKING: | 42 case InputHandlerProxy::DID_HANDLE_NON_BLOCKING: |
| 41 return INPUT_EVENT_ACK_STATE_SET_NON_BLOCKING; | 43 return INPUT_EVENT_ACK_STATE_SET_NON_BLOCKING; |
| 42 } | 44 } |
| 43 NOTREACHED(); | 45 NOTREACHED(); |
| 44 return INPUT_EVENT_ACK_STATE_UNKNOWN; | 46 return INPUT_EVENT_ACK_STATE_UNKNOWN; |
| 45 } | 47 } |
| 46 | 48 |
| 47 } // namespace | 49 } // namespace |
| (...skipping 185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 233 std::unique_ptr<ui::DidOverscrollParams> overscroll_params) { | 235 std::unique_ptr<ui::DidOverscrollParams> overscroll_params) { |
| 234 InputEventAckState input_event_ack_state = | 236 InputEventAckState input_event_ack_state = |
| 235 InputEventDispositionToAck(event_disposition); | 237 InputEventDispositionToAck(event_disposition); |
| 236 switch (input_event_ack_state) { | 238 switch (input_event_ack_state) { |
| 237 case INPUT_EVENT_ACK_STATE_CONSUMED: | 239 case INPUT_EVENT_ACK_STATE_CONSUMED: |
| 238 renderer_scheduler_->DidHandleInputEventOnCompositorThread( | 240 renderer_scheduler_->DidHandleInputEventOnCompositorThread( |
| 239 *input_event, | 241 *input_event, |
| 240 RendererScheduler::InputEventState::EVENT_CONSUMED_BY_COMPOSITOR); | 242 RendererScheduler::InputEventState::EVENT_CONSUMED_BY_COMPOSITOR); |
| 241 break; | 243 break; |
| 242 case INPUT_EVENT_ACK_STATE_NOT_CONSUMED: | 244 case INPUT_EVENT_ACK_STATE_NOT_CONSUMED: |
| 245 case INPUT_EVENT_ACK_STATE_NOT_CONSUMED_NON_BLOCKING: |
| 243 renderer_scheduler_->DidHandleInputEventOnCompositorThread( | 246 renderer_scheduler_->DidHandleInputEventOnCompositorThread( |
| 244 *input_event, | 247 *input_event, |
| 245 RendererScheduler::InputEventState::EVENT_FORWARDED_TO_MAIN_THREAD); | 248 RendererScheduler::InputEventState::EVENT_FORWARDED_TO_MAIN_THREAD); |
| 246 break; | 249 break; |
| 247 default: | 250 default: |
| 248 break; | 251 break; |
| 249 } | 252 } |
| 250 callback.Run(input_event_ack_state, std::move(input_event), latency_info, | 253 callback.Run(input_event_ack_state, std::move(input_event), latency_info, |
| 251 std::move(overscroll_params)); | 254 std::move(overscroll_params)); |
| 252 } | 255 } |
| 253 | 256 |
| 254 void InputHandlerManager::DidOverscroll(int routing_id, | 257 void InputHandlerManager::DidOverscroll(int routing_id, |
| 255 const ui::DidOverscrollParams& params) { | 258 const ui::DidOverscrollParams& params) { |
| 256 client_->DidOverscroll(routing_id, params); | 259 client_->DidOverscroll(routing_id, params); |
| 257 } | 260 } |
| 258 | 261 |
| 259 void InputHandlerManager::DidStartFlinging(int routing_id) { | |
| 260 client_->DidStartFlinging(routing_id); | |
| 261 } | |
| 262 | |
| 263 void InputHandlerManager::DidStopFlinging(int routing_id) { | 262 void InputHandlerManager::DidStopFlinging(int routing_id) { |
| 264 client_->DidStopFlinging(routing_id); | 263 client_->DidStopFlinging(routing_id); |
| 265 } | 264 } |
| 266 | 265 |
| 267 void InputHandlerManager::DidAnimateForInput() { | 266 void InputHandlerManager::DidAnimateForInput() { |
| 268 renderer_scheduler_->DidAnimateForInputOnCompositorThread(); | 267 renderer_scheduler_->DidAnimateForInputOnCompositorThread(); |
| 269 } | 268 } |
| 270 | 269 |
| 271 void InputHandlerManager::NeedsMainFrame(int routing_id) { | 270 void InputHandlerManager::NeedsMainFrame(int routing_id) { |
| 272 DCHECK(task_runner_->BelongsToCurrentThread()); | 271 DCHECK(task_runner_->BelongsToCurrentThread()); |
| 273 auto it = input_handlers_.find(routing_id); | 272 auto it = input_handlers_.find(routing_id); |
| 274 if (it == input_handlers_.end()) | 273 if (it == input_handlers_.end()) |
| 275 return; | 274 return; |
| 276 it->second->NeedsMainFrame(); | 275 it->second->NeedsMainFrame(); |
| 277 } | 276 } |
| 278 | 277 |
| 279 void InputHandlerManager::DispatchNonBlockingEventToMainThread( | 278 void InputHandlerManager::DispatchNonBlockingEventToMainThread( |
| 280 int routing_id, | 279 int routing_id, |
| 281 ui::ScopedWebInputEvent event, | 280 ui::ScopedWebInputEvent event, |
| 282 const ui::LatencyInfo& latency_info) { | 281 const ui::LatencyInfo& latency_info) { |
| 283 DCHECK(task_runner_->BelongsToCurrentThread()); | 282 DCHECK(task_runner_->BelongsToCurrentThread()); |
| 284 client_->DispatchNonBlockingEventToMainThread(routing_id, std::move(event), | 283 client_->DispatchNonBlockingEventToMainThread(routing_id, std::move(event), |
| 285 latency_info); | 284 latency_info); |
| 286 } | 285 } |
| 287 | 286 |
| 288 } // namespace content | 287 } // namespace content |
| OLD | NEW |