OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/render_widget.h" | 5 #include "content/renderer/render_widget.h" |
6 | 6 |
7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
8 #include "base/bind.h" | 8 #include "base/bind.h" |
9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 1207 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1218 kInputHandlingTimeThrottlingThresholdMicroseconds; | 1218 kInputHandlingTimeThrottlingThresholdMicroseconds; |
1219 } | 1219 } |
1220 | 1220 |
1221 TRACE_EVENT_SYNTHETIC_DELAY_END("blink.HandleInputEvent"); | 1221 TRACE_EVENT_SYNTHETIC_DELAY_END("blink.HandleInputEvent"); |
1222 | 1222 |
1223 // Note that we can't use handling_event_type_ here since it will be overriden | 1223 // Note that we can't use handling_event_type_ here since it will be overriden |
1224 // by reentrant calls for events after the paused one. | 1224 // by reentrant calls for events after the paused one. |
1225 bool no_ack = ignore_ack_for_mouse_move_from_debugger_ && | 1225 bool no_ack = ignore_ack_for_mouse_move_from_debugger_ && |
1226 input_event->type == WebInputEvent::MouseMove; | 1226 input_event->type == WebInputEvent::MouseMove; |
1227 if (!WebInputEventTraits::IgnoresAckDisposition(*input_event) && !no_ack) { | 1227 if (!WebInputEventTraits::IgnoresAckDisposition(*input_event) && !no_ack) { |
1228 InputHostMsg_HandleInputEvent_ACK_Params ack; | 1228 // Send AsyncTouchEvent_ACK for async touch moves, and InputEvent_ACK for |
1229 ack.type = input_event->type; | 1229 // all other types of events. |
1230 ack.state = ack_result; | 1230 scoped_ptr<IPC::Message> response; |
1231 ack.latency = swap_latency_info; | 1231 bool is_async_touch_move = false; |
1232 scoped_ptr<IPC::Message> response( | 1232 if (WebInputEvent::isTouchEventType(input_event->type)) { |
1233 new InputHostMsg_HandleInputEvent_ACK(routing_id_, ack)); | 1233 const WebTouchEvent& touch = |
1234 static_cast<const WebTouchEvent&>(*input_event); | |
1235 if (touch.type == WebInputEvent::TouchMove && !touch.cancelable) | |
tdresser
2015/03/25 14:16:18
Can't we just:
if(touch.type == WebInputEvent::Tou
lanwei
2015/03/26 11:54:38
We need to cast to WebTouchEvent.
| |
1236 is_async_touch_move = true; | |
1237 } | |
1238 if (is_async_touch_move) { | |
1239 InputHostMsg_HandleUncancelableTouchMoveEvent_ACK_Params ack; | |
1240 ack.type = input_event->type; | |
1241 response = scoped_ptr<IPC::Message>( | |
1242 new InputHostMsg_HandleUncancelableTouchMoveEvent_ACK(routing_id_, | |
1243 ack)); | |
1244 } else { | |
1245 InputHostMsg_HandleInputEvent_ACK_Params ack; | |
1246 ack.type = input_event->type; | |
1247 ack.state = ack_result; | |
1248 ack.latency = swap_latency_info; | |
1249 response = scoped_ptr<IPC::Message>( | |
1250 new InputHostMsg_HandleInputEvent_ACK(routing_id_, ack)); | |
1251 } | |
1252 | |
1234 if (rate_limiting_wanted && frame_pending && !is_hidden_) { | 1253 if (rate_limiting_wanted && frame_pending && !is_hidden_) { |
1235 // We want to rate limit the input events in this case, so we'll wait for | 1254 // We want to rate limit the input events in this case, so we'll wait for |
1236 // painting to finish before ACKing this message. | 1255 // painting to finish before ACKing this message. |
1237 TRACE_EVENT_INSTANT0("renderer", | 1256 TRACE_EVENT_INSTANT0("renderer", |
1238 "RenderWidget::OnHandleInputEvent ack throttled", | 1257 "RenderWidget::OnHandleInputEvent ack throttled", |
1239 TRACE_EVENT_SCOPE_THREAD); | 1258 TRACE_EVENT_SCOPE_THREAD); |
1240 if (pending_input_event_ack_) { | 1259 if (pending_input_event_ack_) { |
1241 TRACE_EVENT_ASYNC_END0("input", "RenderWidget::ThrottledInputEventAck", | 1260 TRACE_EVENT_ASYNC_END0("input", "RenderWidget::ThrottledInputEventAck", |
1242 pending_input_event_ack_.get()); | 1261 pending_input_event_ack_.get()); |
1243 // As two different kinds of events could cause us to postpone an ack | 1262 // As two different kinds of events could cause us to postpone an ack |
(...skipping 1179 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2423 void RenderWidget::RegisterVideoHoleFrame(RenderFrameImpl* frame) { | 2442 void RenderWidget::RegisterVideoHoleFrame(RenderFrameImpl* frame) { |
2424 video_hole_frames_.AddObserver(frame); | 2443 video_hole_frames_.AddObserver(frame); |
2425 } | 2444 } |
2426 | 2445 |
2427 void RenderWidget::UnregisterVideoHoleFrame(RenderFrameImpl* frame) { | 2446 void RenderWidget::UnregisterVideoHoleFrame(RenderFrameImpl* frame) { |
2428 video_hole_frames_.RemoveObserver(frame); | 2447 video_hole_frames_.RemoveObserver(frame); |
2429 } | 2448 } |
2430 #endif // defined(VIDEO_HOLE) | 2449 #endif // defined(VIDEO_HOLE) |
2431 | 2450 |
2432 } // namespace content | 2451 } // namespace content |
OLD | NEW |