Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(622)

Side by Side Diff: cc/trees/layer_tree_host_impl.cc

Issue 365463003: Implement scroll handler latency tracking (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698