OLD | NEW |
1 // Copyright 2011 The Chromium Authors. All rights reserved. | 1 // Copyright 2011 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 "cc/trees/layer_tree_host_impl.h" | 5 #include "cc/trees/layer_tree_host_impl.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <limits> | 8 #include <limits> |
9 | 9 |
10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
(...skipping 485 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
496 return layer_impl != NULL; | 496 return layer_impl != NULL; |
497 } | 497 } |
498 | 498 |
499 scoped_ptr<SwapPromiseMonitor> | 499 scoped_ptr<SwapPromiseMonitor> |
500 LayerTreeHostImpl::CreateLatencyInfoSwapPromiseMonitor( | 500 LayerTreeHostImpl::CreateLatencyInfoSwapPromiseMonitor( |
501 ui::LatencyInfo* latency) { | 501 ui::LatencyInfo* latency) { |
502 return scoped_ptr<SwapPromiseMonitor>( | 502 return scoped_ptr<SwapPromiseMonitor>( |
503 new LatencyInfoSwapPromiseMonitor(latency, NULL, this)); | 503 new LatencyInfoSwapPromiseMonitor(latency, NULL, this)); |
504 } | 504 } |
505 | 505 |
| 506 void LayerTreeHostImpl::QueueScrollUpdateLatencyInfo( |
| 507 const ui::LatencyInfo& latency_info) { |
| 508 scroll_update_latency_infos_.push_back(latency_info); |
| 509 } |
| 510 |
506 void LayerTreeHostImpl::TrackDamageForAllSurfaces( | 511 void LayerTreeHostImpl::TrackDamageForAllSurfaces( |
507 LayerImpl* root_draw_layer, | 512 LayerImpl* root_draw_layer, |
508 const LayerImplList& render_surface_layer_list) { | 513 const LayerImplList& render_surface_layer_list) { |
509 // For now, we use damage tracking to compute a global scissor. To do this, we | 514 // For now, we use damage tracking to compute a global scissor. To do this, we |
510 // must compute all damage tracking before drawing anything, so that we know | 515 // must compute all damage tracking before drawing anything, so that we know |
511 // the root damage rect. The root damage rect is then used to scissor each | 516 // the root damage rect. The root damage rect is then used to scissor each |
512 // surface. | 517 // surface. |
513 | 518 |
514 for (int surface_index = render_surface_layer_list.size() - 1; | 519 for (int surface_index = render_surface_layer_list.size() - 1; |
515 surface_index >= 0; | 520 surface_index >= 0; |
(...skipping 1939 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2455 // which the layer moved. | 2460 // which the layer moved. |
2456 gfx::Vector2dF perpendicular_axis(-applied_delta.y(), applied_delta.x()); | 2461 gfx::Vector2dF perpendicular_axis(-applied_delta.y(), applied_delta.x()); |
2457 pending_delta = MathUtil::ProjectVector(pending_delta, perpendicular_axis); | 2462 pending_delta = MathUtil::ProjectVector(pending_delta, perpendicular_axis); |
2458 | 2463 |
2459 if (gfx::ToRoundedVector2d(pending_delta).IsZero()) | 2464 if (gfx::ToRoundedVector2d(pending_delta).IsZero()) |
2460 break; | 2465 break; |
2461 } | 2466 } |
2462 | 2467 |
2463 bool did_scroll_content = did_scroll_x || did_scroll_y; | 2468 bool did_scroll_content = did_scroll_x || did_scroll_y; |
2464 if (did_scroll_content) { | 2469 if (did_scroll_content) { |
| 2470 // If we are scrolling with an active scroll handler, forward latency |
| 2471 // tracking information to the main thread so the delay introduced by the |
| 2472 // handler is accounted for. |
| 2473 if (scroll_affects_scroll_handler()) |
| 2474 NotifySwapPromiseMonitorsOfForwardingToMainThread(); |
2465 client_->SetNeedsCommitOnImplThread(); | 2475 client_->SetNeedsCommitOnImplThread(); |
2466 SetNeedsRedraw(); | 2476 SetNeedsRedraw(); |
2467 client_->RenewTreePriority(); | 2477 client_->RenewTreePriority(); |
2468 } | 2478 } |
2469 | 2479 |
2470 // Scrolling along an axis resets accumulated root overscroll for that axis. | 2480 // Scrolling along an axis resets accumulated root overscroll for that axis. |
2471 if (did_scroll_x) | 2481 if (did_scroll_x) |
2472 accumulated_root_overscroll_.set_x(0); | 2482 accumulated_root_overscroll_.set_x(0); |
2473 if (did_scroll_y) | 2483 if (did_scroll_y) |
2474 accumulated_root_overscroll_.set_y(0); | 2484 accumulated_root_overscroll_.set_y(0); |
(...skipping 281 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2756 for (size_t i = 0; i < layer_impl->children().size(); ++i) | 2766 for (size_t i = 0; i < layer_impl->children().size(); ++i) |
2757 CollectScrollDeltas(scroll_info, layer_impl->children()[i]); | 2767 CollectScrollDeltas(scroll_info, layer_impl->children()[i]); |
2758 } | 2768 } |
2759 | 2769 |
2760 scoped_ptr<ScrollAndScaleSet> LayerTreeHostImpl::ProcessScrollDeltas() { | 2770 scoped_ptr<ScrollAndScaleSet> LayerTreeHostImpl::ProcessScrollDeltas() { |
2761 scoped_ptr<ScrollAndScaleSet> scroll_info(new ScrollAndScaleSet()); | 2771 scoped_ptr<ScrollAndScaleSet> scroll_info(new ScrollAndScaleSet()); |
2762 | 2772 |
2763 CollectScrollDeltas(scroll_info.get(), active_tree_->root_layer()); | 2773 CollectScrollDeltas(scroll_info.get(), active_tree_->root_layer()); |
2764 scroll_info->page_scale_delta = active_tree_->page_scale_delta(); | 2774 scroll_info->page_scale_delta = active_tree_->page_scale_delta(); |
2765 active_tree_->set_sent_page_scale_delta(scroll_info->page_scale_delta); | 2775 active_tree_->set_sent_page_scale_delta(scroll_info->page_scale_delta); |
| 2776 std::swap(scroll_info->latency_infos, scroll_update_latency_infos_); |
2766 | 2777 |
2767 return scroll_info.Pass(); | 2778 return scroll_info.Pass(); |
2768 } | 2779 } |
2769 | 2780 |
2770 void LayerTreeHostImpl::SetFullRootLayerDamage() { | 2781 void LayerTreeHostImpl::SetFullRootLayerDamage() { |
2771 SetViewportDamage(gfx::Rect(DrawViewportSize())); | 2782 SetViewportDamage(gfx::Rect(DrawViewportSize())); |
2772 } | 2783 } |
2773 | 2784 |
2774 void LayerTreeHostImpl::RunOnDemandRasterTask(Task* on_demand_raster_task) { | 2785 void LayerTreeHostImpl::RunOnDemandRasterTask(Task* on_demand_raster_task) { |
2775 DCHECK(on_demand_task_graph_runner_); | 2786 DCHECK(on_demand_task_graph_runner_); |
(...skipping 356 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3132 void LayerTreeHostImpl::RemoveSwapPromiseMonitor(SwapPromiseMonitor* monitor) { | 3143 void LayerTreeHostImpl::RemoveSwapPromiseMonitor(SwapPromiseMonitor* monitor) { |
3133 swap_promise_monitor_.erase(monitor); | 3144 swap_promise_monitor_.erase(monitor); |
3134 } | 3145 } |
3135 | 3146 |
3136 void LayerTreeHostImpl::NotifySwapPromiseMonitorsOfSetNeedsRedraw() { | 3147 void LayerTreeHostImpl::NotifySwapPromiseMonitorsOfSetNeedsRedraw() { |
3137 std::set<SwapPromiseMonitor*>::iterator it = swap_promise_monitor_.begin(); | 3148 std::set<SwapPromiseMonitor*>::iterator it = swap_promise_monitor_.begin(); |
3138 for (; it != swap_promise_monitor_.end(); it++) | 3149 for (; it != swap_promise_monitor_.end(); it++) |
3139 (*it)->OnSetNeedsRedrawOnImpl(); | 3150 (*it)->OnSetNeedsRedrawOnImpl(); |
3140 } | 3151 } |
3141 | 3152 |
| 3153 void LayerTreeHostImpl::NotifySwapPromiseMonitorsOfForwardingToMainThread() { |
| 3154 std::set<SwapPromiseMonitor*>::iterator it = swap_promise_monitor_.begin(); |
| 3155 for (; it != swap_promise_monitor_.end(); it++) |
| 3156 (*it)->OnForwardScrollUpdateToMainThreadOnImpl(); |
| 3157 } |
| 3158 |
3142 void LayerTreeHostImpl::RegisterPictureLayerImpl(PictureLayerImpl* layer) { | 3159 void LayerTreeHostImpl::RegisterPictureLayerImpl(PictureLayerImpl* layer) { |
3143 DCHECK(std::find(picture_layers_.begin(), picture_layers_.end(), layer) == | 3160 DCHECK(std::find(picture_layers_.begin(), picture_layers_.end(), layer) == |
3144 picture_layers_.end()); | 3161 picture_layers_.end()); |
3145 picture_layers_.push_back(layer); | 3162 picture_layers_.push_back(layer); |
3146 } | 3163 } |
3147 | 3164 |
3148 void LayerTreeHostImpl::UnregisterPictureLayerImpl(PictureLayerImpl* layer) { | 3165 void LayerTreeHostImpl::UnregisterPictureLayerImpl(PictureLayerImpl* layer) { |
3149 std::vector<PictureLayerImpl*>::iterator it = | 3166 std::vector<PictureLayerImpl*>::iterator it = |
3150 std::find(picture_layers_.begin(), picture_layers_.end(), layer); | 3167 std::find(picture_layers_.begin(), picture_layers_.end(), layer); |
3151 DCHECK(it != picture_layers_.end()); | 3168 DCHECK(it != picture_layers_.end()); |
3152 picture_layers_.erase(it); | 3169 picture_layers_.erase(it); |
3153 } | 3170 } |
3154 | 3171 |
3155 } // namespace cc | 3172 } // namespace cc |
OLD | NEW |