| Index: content/browser/frame_host/render_widget_host_view_child_frame.cc
|
| diff --git a/content/browser/frame_host/render_widget_host_view_child_frame.cc b/content/browser/frame_host/render_widget_host_view_child_frame.cc
|
| index 5f4c0403202b0c7ad98ea480ac1c96ec1effa996..3e974bf63b72413db22fcf3f774f679bd62d74d3 100644
|
| --- a/content/browser/frame_host/render_widget_host_view_child_frame.cc
|
| +++ b/content/browser/frame_host/render_widget_host_view_child_frame.cc
|
| @@ -43,10 +43,7 @@ RenderWidgetHostViewChildFrame::RenderWidgetHostViewChildFrame(
|
| frame_connector_(nullptr),
|
| weak_factory_(this) {
|
| id_allocator_ = CreateSurfaceIdAllocator();
|
| - if (host_->delegate() && host_->delegate()->GetInputEventRouter()) {
|
| - host_->delegate()->GetInputEventRouter()->AddSurfaceIdNamespaceOwner(
|
| - GetSurfaceIdNamespace(), this);
|
| - }
|
| + RegisterSurfaceNamespaceId();
|
|
|
| host_->SetView(this);
|
| }
|
| @@ -243,6 +240,24 @@ void RenderWidgetHostViewChildFrame::UnlockCompositingSurface() {
|
| NOTIMPLEMENTED();
|
| }
|
|
|
| +void RenderWidgetHostViewChildFrame::RegisterSurfaceNamespaceId() {
|
| + DCHECK(host_);
|
| + if (host_->delegate() && host_->delegate()->GetInputEventRouter()) {
|
| + RenderWidgetHostInputEventRouter* router =
|
| + host_->delegate()->GetInputEventRouter();
|
| + if (!router->is_registered(GetSurfaceIdNamespace()))
|
| + router->AddSurfaceIdNamespaceOwner(GetSurfaceIdNamespace(), this);
|
| + }
|
| +}
|
| +
|
| +void RenderWidgetHostViewChildFrame::UnregisterSurfaceNamespaceId() {
|
| + DCHECK(host_);
|
| + if (host_->delegate() && host_->delegate()->GetInputEventRouter()) {
|
| + host_->delegate()->GetInputEventRouter()->RemoveSurfaceIdNamespaceOwner(
|
| + GetSurfaceIdNamespace());
|
| + }
|
| +}
|
| +
|
| void RenderWidgetHostViewChildFrame::SurfaceDrawn(uint32_t output_surface_id,
|
| cc::SurfaceDrawStatus drawn) {
|
| cc::CompositorFrameAck ack;
|
| @@ -346,12 +361,14 @@ gfx::Rect RenderWidgetHostViewChildFrame::GetBoundsInRootWindow() {
|
| return GetViewBounds();
|
| }
|
|
|
| -#if defined(USE_AURA)
|
| void RenderWidgetHostViewChildFrame::ProcessAckedTouchEvent(
|
| const TouchEventWithLatencyInfo& touch,
|
| InputEventAckState ack_result) {
|
| + if (!frame_connector_)
|
| + return;
|
| +
|
| + frame_connector_->ForwardProcessAckedTouchEvent(touch, ack_result);
|
| }
|
| -#endif // defined(USE_AURA)
|
|
|
| bool RenderWidgetHostViewChildFrame::LockMouse() {
|
| return false;
|
| @@ -380,6 +397,17 @@ void RenderWidgetHostViewChildFrame::ProcessMouseWheelEvent(
|
| host_->ForwardWheelEvent(event);
|
| }
|
|
|
| +void RenderWidgetHostViewChildFrame::ProcessTouchEvent(
|
| + const blink::WebTouchEvent& event,
|
| + const ui::LatencyInfo& latency) {
|
| + if (event.type == blink::WebInputEvent::TouchStart &&
|
| + frame_connector_ && !frame_connector_->HasFocus()) {
|
| + frame_connector_->Focus();
|
| + }
|
| +
|
| + host_->ForwardTouchEventWithLatencyInfo(event, latency);
|
| +}
|
| +
|
| gfx::Point RenderWidgetHostViewChildFrame::TransformPointToRootCoordSpace(
|
| const gfx::Point& point) {
|
| if (!frame_connector_)
|
|
|