| 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/browser/renderer_host/render_widget_host_view_android.h" | 5 #include "content/browser/renderer_host/render_widget_host_view_android.h" |
| 6 | 6 |
| 7 #include <android/bitmap.h> | 7 #include <android/bitmap.h> |
| 8 | 8 |
| 9 #include <utility> | 9 #include <utility> |
| 10 | 10 |
| (...skipping 1093 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1104 std::unique_ptr<SyntheticGestureTarget> | 1104 std::unique_ptr<SyntheticGestureTarget> |
| 1105 RenderWidgetHostViewAndroid::CreateSyntheticGestureTarget() { | 1105 RenderWidgetHostViewAndroid::CreateSyntheticGestureTarget() { |
| 1106 return std::unique_ptr<SyntheticGestureTarget>( | 1106 return std::unique_ptr<SyntheticGestureTarget>( |
| 1107 new SyntheticGestureTargetAndroid( | 1107 new SyntheticGestureTargetAndroid( |
| 1108 host_, content_view_core_->CreateMotionEventSynthesizer())); | 1108 host_, content_view_core_->CreateMotionEventSynthesizer())); |
| 1109 } | 1109 } |
| 1110 | 1110 |
| 1111 void RenderWidgetHostViewAndroid::SendReclaimCompositorResources( | 1111 void RenderWidgetHostViewAndroid::SendReclaimCompositorResources( |
| 1112 bool is_swap_ack) { | 1112 bool is_swap_ack) { |
| 1113 DCHECK(host_); | 1113 DCHECK(host_); |
| 1114 host_->SendReclaimCompositorResources(is_swap_ack, | 1114 if (is_swap_ack) |
| 1115 surface_returned_resources_); | 1115 renderer_compositor_frame_sink_->DidReceiveCompositorFrameAck(); |
| 1116 renderer_compositor_frame_sink_->ReclaimResources( |
| 1117 surface_returned_resources_); |
| 1116 surface_returned_resources_.clear(); | 1118 surface_returned_resources_.clear(); |
| 1117 } | 1119 } |
| 1118 | 1120 |
| 1119 void RenderWidgetHostViewAndroid::DidReceiveCompositorFrameAck() { | 1121 void RenderWidgetHostViewAndroid::DidReceiveCompositorFrameAck() { |
| 1120 RunAckCallbacks(); | 1122 RunAckCallbacks(); |
| 1121 } | 1123 } |
| 1122 | 1124 |
| 1123 void RenderWidgetHostViewAndroid::ReclaimResources( | 1125 void RenderWidgetHostViewAndroid::ReclaimResources( |
| 1124 const cc::ReturnedResourceArray& resources) { | 1126 const cc::ReturnedResourceArray& resources) { |
| 1125 if (resources.empty()) | 1127 if (resources.empty()) |
| 1126 return; | 1128 return; |
| 1127 std::copy(resources.begin(), resources.end(), | 1129 std::copy(resources.begin(), resources.end(), |
| 1128 std::back_inserter(surface_returned_resources_)); | 1130 std::back_inserter(surface_returned_resources_)); |
| 1129 if (ack_callbacks_.empty()) | 1131 if (ack_callbacks_.empty()) |
| 1130 SendReclaimCompositorResources(false /* is_swap_ack */); | 1132 SendReclaimCompositorResources(false /* is_swap_ack */); |
| 1131 } | 1133 } |
| 1132 | 1134 |
| 1133 void RenderWidgetHostViewAndroid::DidCreateNewRendererCompositorFrameSink() { | 1135 void RenderWidgetHostViewAndroid::DidCreateNewRendererCompositorFrameSink( |
| 1136 cc::mojom::MojoCompositorFrameSinkClient* renderer_compositor_frame_sink) { |
| 1134 delegated_frame_host_->CompositorFrameSinkChanged(); | 1137 delegated_frame_host_->CompositorFrameSinkChanged(); |
| 1138 renderer_compositor_frame_sink_ = renderer_compositor_frame_sink; |
| 1135 // Accumulated resources belong to the old RendererCompositorFrameSink and | 1139 // Accumulated resources belong to the old RendererCompositorFrameSink and |
| 1136 // should not be returned. | 1140 // should not be returned. |
| 1137 surface_returned_resources_.clear(); | 1141 surface_returned_resources_.clear(); |
| 1138 } | 1142 } |
| 1139 | 1143 |
| 1140 void RenderWidgetHostViewAndroid::SubmitCompositorFrame( | 1144 void RenderWidgetHostViewAndroid::SubmitCompositorFrame( |
| 1141 const cc::LocalSurfaceId& local_surface_id, | 1145 const cc::LocalSurfaceId& local_surface_id, |
| 1142 cc::CompositorFrame frame) { | 1146 cc::CompositorFrame frame) { |
| 1143 last_scroll_offset_ = frame.metadata.root_scroll_offset; | 1147 last_scroll_offset_ = frame.metadata.root_scroll_offset; |
| 1144 DCHECK(delegated_frame_host_); | 1148 DCHECK(delegated_frame_host_); |
| (...skipping 419 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1564 void RenderWidgetHostViewAndroid::SendBeginFrame(cc::BeginFrameArgs args) { | 1568 void RenderWidgetHostViewAndroid::SendBeginFrame(cc::BeginFrameArgs args) { |
| 1565 TRACE_EVENT2("cc", "RenderWidgetHostViewAndroid::SendBeginFrame", | 1569 TRACE_EVENT2("cc", "RenderWidgetHostViewAndroid::SendBeginFrame", |
| 1566 "frame_number", args.sequence_number, "frame_time_us", | 1570 "frame_number", args.sequence_number, "frame_time_us", |
| 1567 args.frame_time.ToInternalValue()); | 1571 args.frame_time.ToInternalValue()); |
| 1568 | 1572 |
| 1569 // Synchronous compositor does not use deadline-based scheduling. | 1573 // Synchronous compositor does not use deadline-based scheduling. |
| 1570 // TODO(brianderson): Replace this hardcoded deadline after Android | 1574 // TODO(brianderson): Replace this hardcoded deadline after Android |
| 1571 // switches to Surfaces and the Browser's commit isn't in the critical path. | 1575 // switches to Surfaces and the Browser's commit isn't in the critical path. |
| 1572 args.deadline = sync_compositor_ ? base::TimeTicks() | 1576 args.deadline = sync_compositor_ ? base::TimeTicks() |
| 1573 : args.frame_time + (args.interval * 0.6); | 1577 : args.frame_time + (args.interval * 0.6); |
| 1574 host_->Send(new ViewMsg_BeginFrame(host_->GetRoutingID(), args)); | 1578 if (sync_compositor_) { |
| 1575 if (sync_compositor_) | 1579 host_->Send(new ViewMsg_BeginFrame(host_->GetRoutingID(), args)); |
| 1576 sync_compositor_->DidSendBeginFrame(view_.GetWindowAndroid()); | 1580 sync_compositor_->DidSendBeginFrame(view_.GetWindowAndroid()); |
| 1581 } else { |
| 1582 renderer_compositor_frame_sink_->OnBeginFrame(args); |
| 1583 } |
| 1577 } | 1584 } |
| 1578 | 1585 |
| 1579 bool RenderWidgetHostViewAndroid::Animate(base::TimeTicks frame_time) { | 1586 bool RenderWidgetHostViewAndroid::Animate(base::TimeTicks frame_time) { |
| 1580 bool needs_animate = false; | 1587 bool needs_animate = false; |
| 1581 if (overscroll_controller_ && !is_in_vr_) { | 1588 if (overscroll_controller_ && !is_in_vr_) { |
| 1582 needs_animate |= overscroll_controller_->Animate( | 1589 needs_animate |= overscroll_controller_->Animate( |
| 1583 frame_time, content_view_core_->GetViewAndroid()->GetLayer()); | 1590 frame_time, content_view_core_->GetViewAndroid()->GetLayer()); |
| 1584 } | 1591 } |
| 1585 if (selection_controller_) | 1592 if (selection_controller_) |
| 1586 needs_animate |= selection_controller_->Animate(frame_time); | 1593 needs_animate |= selection_controller_->Animate(frame_time); |
| (...skipping 589 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2176 | 2183 |
| 2177 ui::WindowAndroidCompositor* compositor = window_android->GetCompositor(); | 2184 ui::WindowAndroidCompositor* compositor = window_android->GetCompositor(); |
| 2178 if (!compositor) | 2185 if (!compositor) |
| 2179 return; | 2186 return; |
| 2180 | 2187 |
| 2181 overscroll_controller_ = base::MakeUnique<OverscrollControllerAndroid>( | 2188 overscroll_controller_ = base::MakeUnique<OverscrollControllerAndroid>( |
| 2182 overscroll_refresh_handler, compositor, view_.GetDipScale()); | 2189 overscroll_refresh_handler, compositor, view_.GetDipScale()); |
| 2183 } | 2190 } |
| 2184 | 2191 |
| 2185 } // namespace content | 2192 } // namespace content |
| OLD | NEW |