| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/browser/frame_host/render_widget_host_view_guest.h" | 5 #include "content/browser/frame_host/render_widget_host_view_guest.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind_helpers.h" | 9 #include "base/bind_helpers.h" |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| (...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 177 DCHECK(guest_->GetOwnerRenderWidgetHostView()); | 177 DCHECK(guest_->GetOwnerRenderWidgetHostView()); |
| 178 RenderWidgetHost* embedder = | 178 RenderWidgetHost* embedder = |
| 179 guest_->GetOwnerRenderWidgetHostView()->GetRenderWidgetHost(); | 179 guest_->GetOwnerRenderWidgetHostView()->GetRenderWidgetHost(); |
| 180 if (!embedder->GetView()->HasFocus()) | 180 if (!embedder->GetView()->HasFocus()) |
| 181 embedder->GetView()->Focus(); | 181 embedder->GetView()->Focus(); |
| 182 | 182 |
| 183 // With direct routing, the embedder would not know to focus the guest on | 183 // With direct routing, the embedder would not know to focus the guest on |
| 184 // click. Sends a synthetic event for the focusing side effect. | 184 // click. Sends a synthetic event for the focusing side effect. |
| 185 // TODO(wjmaclean): When we remove BrowserPlugin, delete this code. | 185 // TODO(wjmaclean): When we remove BrowserPlugin, delete this code. |
| 186 // http://crbug.com/533069 | 186 // http://crbug.com/533069 |
| 187 MaybeSendSyntheticTapGesture( | 187 MaybeSendSyntheticTapGesture(event.positionInWidget(), |
| 188 blink::WebFloatPoint(event.x, event.y), | 188 event.positionInScreen()); |
| 189 blink::WebFloatPoint(event.globalX, event.globalY)); | |
| 190 } | 189 } |
| 191 host_->ForwardMouseEventWithLatencyInfo(event, latency); | 190 host_->ForwardMouseEventWithLatencyInfo(event, latency); |
| 192 } | 191 } |
| 193 | 192 |
| 194 void RenderWidgetHostViewGuest::ProcessTouchEvent( | 193 void RenderWidgetHostViewGuest::ProcessTouchEvent( |
| 195 const blink::WebTouchEvent& event, | 194 const blink::WebTouchEvent& event, |
| 196 const ui::LatencyInfo& latency) { | 195 const ui::LatencyInfo& latency) { |
| 197 if (event.type() == blink::WebInputEvent::TouchStart) { | 196 if (event.type() == blink::WebInputEvent::TouchStart) { |
| 198 DCHECK(guest_->GetOwnerRenderWidgetHostView()); | 197 DCHECK(guest_->GetOwnerRenderWidgetHostView()); |
| 199 RenderWidgetHost* embedder = | 198 RenderWidgetHost* embedder = |
| (...skipping 357 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 557 int browser_plugin_instance_id, | 556 int browser_plugin_instance_id, |
| 558 const blink::WebInputEvent* event) { | 557 const blink::WebInputEvent* event) { |
| 559 // WebMouseWheelEvents go into a queue, and may not be forwarded to the | 558 // WebMouseWheelEvents go into a queue, and may not be forwarded to the |
| 560 // renderer until after this method goes out of scope. Therefore we need to | 559 // renderer until after this method goes out of scope. Therefore we need to |
| 561 // explicitly remove the additional device scale factor from the coordinates | 560 // explicitly remove the additional device scale factor from the coordinates |
| 562 // before allowing the event to be queued. | 561 // before allowing the event to be queued. |
| 563 if (IsUseZoomForDSFEnabled() && | 562 if (IsUseZoomForDSFEnabled() && |
| 564 event->type() == blink::WebInputEvent::MouseWheel) { | 563 event->type() == blink::WebInputEvent::MouseWheel) { |
| 565 blink::WebMouseWheelEvent rescaled_event = | 564 blink::WebMouseWheelEvent rescaled_event = |
| 566 *static_cast<const blink::WebMouseWheelEvent*>(event); | 565 *static_cast<const blink::WebMouseWheelEvent*>(event); |
| 567 rescaled_event.x /= current_device_scale_factor(); | 566 rescaled_event.setPositionInWidget( |
| 568 rescaled_event.y /= current_device_scale_factor(); | 567 rescaled_event.positionInWidget().x / current_device_scale_factor(), |
| 568 rescaled_event.positionInWidget().y / current_device_scale_factor()); |
| 569 rescaled_event.deltaX /= current_device_scale_factor(); | 569 rescaled_event.deltaX /= current_device_scale_factor(); |
| 570 rescaled_event.deltaY /= current_device_scale_factor(); | 570 rescaled_event.deltaY /= current_device_scale_factor(); |
| 571 rescaled_event.wheelTicksX /= current_device_scale_factor(); | 571 rescaled_event.wheelTicksX /= current_device_scale_factor(); |
| 572 rescaled_event.wheelTicksY /= current_device_scale_factor(); | 572 rescaled_event.wheelTicksY /= current_device_scale_factor(); |
| 573 ui::LatencyInfo latency_info(ui::SourceEventType::WHEEL); | 573 ui::LatencyInfo latency_info(ui::SourceEventType::WHEEL); |
| 574 host_->ForwardWheelEventWithLatencyInfo(rescaled_event, latency_info); | 574 host_->ForwardWheelEventWithLatencyInfo(rescaled_event, latency_info); |
| 575 return; | 575 return; |
| 576 } | 576 } |
| 577 | 577 |
| 578 ScopedInputScaleDisabler disable(host_, current_device_scale_factor()); | 578 ScopedInputScaleDisabler disable(host_, current_device_scale_factor()); |
| 579 if (blink::WebInputEvent::isMouseEventType(event->type())) { | 579 if (blink::WebInputEvent::isMouseEventType(event->type())) { |
| 580 // The mouse events for BrowserPlugin are modified by all | 580 // The mouse events for BrowserPlugin are modified by all |
| 581 // the CSS transforms applied on the <object> and embedder. As a result of | 581 // the CSS transforms applied on the <object> and embedder. As a result of |
| 582 // this, the coordinates passed on to the guest renderer are potentially | 582 // this, the coordinates passed on to the guest renderer are potentially |
| 583 // incorrect to determine the position of the context menu(they are not the | 583 // incorrect to determine the position of the context menu(they are not the |
| 584 // actual X, Y of the window). As a hack, we report the last location of a | 584 // actual X, Y of the window). As a hack, we report the last location of a |
| 585 // right mouse up to the BrowserPluginGuest to inform it of the next | 585 // right mouse up to the BrowserPluginGuest to inform it of the next |
| 586 // potential location for context menu (BUG=470087). | 586 // potential location for context menu (BUG=470087). |
| 587 // TODO(ekaramad): Find a better and more fundamental solution. Could the | 587 // TODO(ekaramad): Find a better and more fundamental solution. Could the |
| 588 // ContextMenuParams be based on global X, Y? | 588 // ContextMenuParams be based on global X, Y? |
| 589 const blink::WebMouseEvent& mouse_event = | 589 const blink::WebMouseEvent& mouse_event = |
| 590 static_cast<const blink::WebMouseEvent&>(*event); | 590 static_cast<const blink::WebMouseEvent&>(*event); |
| 591 // A MouseDown on the ButtonRight could suggest a ContextMenu. | 591 // A MouseDown on the ButtonRight could suggest a ContextMenu. |
| 592 if (guest_ && mouse_event.type() == blink::WebInputEvent::MouseDown && | 592 if (guest_ && mouse_event.type() == blink::WebInputEvent::MouseDown && |
| 593 mouse_event.button == blink::WebPointerProperties::Button::Right) | 593 mouse_event.button == blink::WebPointerProperties::Button::Right) |
| 594 guest_->SetContextMenuPosition( | 594 guest_->SetContextMenuPosition( |
| 595 gfx::Point(mouse_event.globalX - GetViewBounds().x(), | 595 gfx::Point(mouse_event.positionInScreen().x - GetViewBounds().x(), |
| 596 mouse_event.globalY - GetViewBounds().y())); | 596 mouse_event.positionInScreen().y - GetViewBounds().y())); |
| 597 host_->ForwardMouseEvent(mouse_event); | 597 host_->ForwardMouseEvent(mouse_event); |
| 598 return; | 598 return; |
| 599 } | 599 } |
| 600 | 600 |
| 601 if (event->type() == blink::WebInputEvent::MouseWheel) { | 601 if (event->type() == blink::WebInputEvent::MouseWheel) { |
| 602 ui::LatencyInfo latency_info(ui::SourceEventType::WHEEL); | 602 ui::LatencyInfo latency_info(ui::SourceEventType::WHEEL); |
| 603 host_->ForwardWheelEventWithLatencyInfo( | 603 host_->ForwardWheelEventWithLatencyInfo( |
| 604 *static_cast<const blink::WebMouseWheelEvent*>(event), latency_info); | 604 *static_cast<const blink::WebMouseWheelEvent*>(event), latency_info); |
| 605 return; | 605 return; |
| 606 } | 606 } |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 644 host_->ForwardGestureEvent(gesture_event); | 644 host_->ForwardGestureEvent(gesture_event); |
| 645 return; | 645 return; |
| 646 } | 646 } |
| 647 } | 647 } |
| 648 | 648 |
| 649 bool RenderWidgetHostViewGuest::HasEmbedderChanged() { | 649 bool RenderWidgetHostViewGuest::HasEmbedderChanged() { |
| 650 return guest_ && guest_->has_attached_since_surface_set(); | 650 return guest_ && guest_->has_attached_since_surface_set(); |
| 651 } | 651 } |
| 652 | 652 |
| 653 } // namespace content | 653 } // namespace content |
| OLD | NEW |