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.h" | 5 #include "cc/trees/layer_tree_host.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <stack> | 8 #include <stack> |
9 #include <string> | 9 #include <string> |
10 | 10 |
(...skipping 25 matching lines...) Expand all Loading... |
36 #include "cc/scheduler/begin_frame_source.h" | 36 #include "cc/scheduler/begin_frame_source.h" |
37 #include "cc/trees/layer_tree_host_client.h" | 37 #include "cc/trees/layer_tree_host_client.h" |
38 #include "cc/trees/layer_tree_host_common.h" | 38 #include "cc/trees/layer_tree_host_common.h" |
39 #include "cc/trees/layer_tree_host_impl.h" | 39 #include "cc/trees/layer_tree_host_impl.h" |
40 #include "cc/trees/layer_tree_impl.h" | 40 #include "cc/trees/layer_tree_impl.h" |
41 #include "cc/trees/occlusion_tracker.h" | 41 #include "cc/trees/occlusion_tracker.h" |
42 #include "cc/trees/single_thread_proxy.h" | 42 #include "cc/trees/single_thread_proxy.h" |
43 #include "cc/trees/thread_proxy.h" | 43 #include "cc/trees/thread_proxy.h" |
44 #include "cc/trees/tree_synchronizer.h" | 44 #include "cc/trees/tree_synchronizer.h" |
45 #include "ui/gfx/geometry/size_conversions.h" | 45 #include "ui/gfx/geometry/size_conversions.h" |
| 46 #include "ui/gfx/geometry/vector2d_conversions.h" |
46 | 47 |
47 namespace { | 48 namespace { |
48 static base::StaticAtomicSequenceNumber s_layer_tree_host_sequence_number; | 49 static base::StaticAtomicSequenceNumber s_layer_tree_host_sequence_number; |
49 } | 50 } |
50 | 51 |
51 namespace cc { | 52 namespace cc { |
52 | 53 |
53 RendererCapabilities::RendererCapabilities(ResourceFormat best_texture_format, | 54 RendererCapabilities::RendererCapabilities(ResourceFormat best_texture_format, |
54 bool allow_partial_texture_updates, | 55 bool allow_partial_texture_updates, |
55 int max_texture_size, | 56 int max_texture_size, |
(...skipping 159 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
215 layer->OnOutputSurfaceCreated(); | 216 layer->OnOutputSurfaceCreated(); |
216 } | 217 } |
217 | 218 |
218 void LayerTreeHost::DeleteContentsTexturesOnImplThread( | 219 void LayerTreeHost::DeleteContentsTexturesOnImplThread( |
219 ResourceProvider* resource_provider) { | 220 ResourceProvider* resource_provider) { |
220 DCHECK(proxy_->IsImplThread()); | 221 DCHECK(proxy_->IsImplThread()); |
221 if (contents_texture_manager_) | 222 if (contents_texture_manager_) |
222 contents_texture_manager_->ClearAllMemory(resource_provider); | 223 contents_texture_manager_->ClearAllMemory(resource_provider); |
223 } | 224 } |
224 | 225 |
| 226 void LayerTreeHost::WillBeginMainFrame() { |
| 227 devtools_instrumentation::WillBeginMainThreadFrame(id(), |
| 228 source_frame_number()); |
| 229 client_->WillBeginMainFrame(); |
| 230 } |
| 231 |
225 void LayerTreeHost::DidBeginMainFrame() { | 232 void LayerTreeHost::DidBeginMainFrame() { |
226 client_->DidBeginMainFrame(); | 233 client_->DidBeginMainFrame(); |
227 } | 234 } |
228 | 235 |
229 void LayerTreeHost::BeginMainFrame(const BeginFrameArgs& args) { | 236 void LayerTreeHost::BeginMainFrame(const BeginFrameArgs& args) { |
230 inside_begin_main_frame_ = true; | 237 inside_begin_main_frame_ = true; |
231 client_->BeginMainFrame(args); | 238 client_->BeginMainFrame(args); |
232 inside_begin_main_frame_ = false; | 239 inside_begin_main_frame_ = false; |
233 } | 240 } |
234 | 241 |
(...skipping 845 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1080 ScopedPtrVector<SwapPromise>::iterator it = info->swap_promises.begin(); | 1087 ScopedPtrVector<SwapPromise>::iterator it = info->swap_promises.begin(); |
1081 for (; it != info->swap_promises.end(); ++it) { | 1088 for (; it != info->swap_promises.end(); ++it) { |
1082 scoped_ptr<SwapPromise> swap_promise(info->swap_promises.take(it)); | 1089 scoped_ptr<SwapPromise> swap_promise(info->swap_promises.take(it)); |
1083 TRACE_EVENT_FLOW_STEP0("input", | 1090 TRACE_EVENT_FLOW_STEP0("input", |
1084 "LatencyInfo.Flow", | 1091 "LatencyInfo.Flow", |
1085 TRACE_ID_DONT_MANGLE(swap_promise->TraceId()), | 1092 TRACE_ID_DONT_MANGLE(swap_promise->TraceId()), |
1086 "Main thread scroll update"); | 1093 "Main thread scroll update"); |
1087 QueueSwapPromise(swap_promise.Pass()); | 1094 QueueSwapPromise(swap_promise.Pass()); |
1088 } | 1095 } |
1089 | 1096 |
1090 gfx::Vector2d inner_viewport_scroll_delta; | 1097 gfx::Vector2dF inner_viewport_scroll_delta; |
1091 gfx::Vector2d outer_viewport_scroll_delta; | 1098 gfx::Vector2dF outer_viewport_scroll_delta; |
1092 | 1099 |
1093 if (root_layer_.get()) { | 1100 if (root_layer_.get()) { |
1094 for (size_t i = 0; i < info->scrolls.size(); ++i) { | 1101 for (size_t i = 0; i < info->scrolls.size(); ++i) { |
1095 Layer* layer = LayerTreeHostCommon::FindLayerInSubtree( | 1102 Layer* layer = LayerTreeHostCommon::FindLayerInSubtree( |
1096 root_layer_.get(), info->scrolls[i].layer_id); | 1103 root_layer_.get(), info->scrolls[i].layer_id); |
1097 if (!layer) | 1104 if (!layer) |
1098 continue; | 1105 continue; |
1099 if (layer == outer_viewport_scroll_layer_.get()) { | 1106 if (layer == outer_viewport_scroll_layer_.get()) { |
1100 outer_viewport_scroll_delta += info->scrolls[i].scroll_delta; | 1107 outer_viewport_scroll_delta += info->scrolls[i].scroll_delta; |
1101 } else if (layer == inner_viewport_scroll_layer_.get()) { | 1108 } else if (layer == inner_viewport_scroll_layer_.get()) { |
(...skipping 22 matching lines...) Expand all Loading... |
1124 if (outer_viewport_scroll_layer_.get()) { | 1131 if (outer_viewport_scroll_layer_.get()) { |
1125 outer_viewport_scroll_layer_->SetScrollOffsetFromImplSide( | 1132 outer_viewport_scroll_layer_->SetScrollOffsetFromImplSide( |
1126 gfx::ScrollOffsetWithDelta( | 1133 gfx::ScrollOffsetWithDelta( |
1127 outer_viewport_scroll_layer_->scroll_offset(), | 1134 outer_viewport_scroll_layer_->scroll_offset(), |
1128 outer_viewport_scroll_delta)); | 1135 outer_viewport_scroll_delta)); |
1129 } | 1136 } |
1130 | 1137 |
1131 ApplyPageScaleDeltaFromImplSide(info->page_scale_delta); | 1138 ApplyPageScaleDeltaFromImplSide(info->page_scale_delta); |
1132 elastic_overscroll_ += info->elastic_overscroll_delta; | 1139 elastic_overscroll_ += info->elastic_overscroll_delta; |
1133 if (!settings_.use_pinch_virtual_viewport) { | 1140 if (!settings_.use_pinch_virtual_viewport) { |
| 1141 // TODO(miletus): Make sure either this code path is totally gone, |
| 1142 // or revisit the flooring here if the old pinch viewport code path |
| 1143 // is causing problems with fractional scroll offset. |
1134 client_->ApplyViewportDeltas( | 1144 client_->ApplyViewportDeltas( |
1135 inner_viewport_scroll_delta + outer_viewport_scroll_delta, | 1145 gfx::ToFlooredVector2d(inner_viewport_scroll_delta + |
1136 info->page_scale_delta, | 1146 outer_viewport_scroll_delta), |
1137 info->top_controls_delta); | 1147 info->page_scale_delta, info->top_controls_delta); |
1138 } else { | 1148 } else { |
1139 // TODO(ccameron): pass the elastic overscroll here so that input events | 1149 // TODO(ccameron): pass the elastic overscroll here so that input events |
1140 // may be translated appropriately. | 1150 // may be translated appropriately. |
1141 client_->ApplyViewportDeltas( | 1151 client_->ApplyViewportDeltas( |
1142 inner_viewport_scroll_delta, outer_viewport_scroll_delta, | 1152 inner_viewport_scroll_delta, outer_viewport_scroll_delta, |
1143 info->elastic_overscroll_delta, info->page_scale_delta, | 1153 info->elastic_overscroll_delta, info->page_scale_delta, |
1144 info->top_controls_delta); | 1154 info->top_controls_delta); |
1145 } | 1155 } |
1146 } | 1156 } |
1147 } | 1157 } |
(...skipping 222 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1370 bool children_need_begin_frames) const { | 1380 bool children_need_begin_frames) const { |
1371 proxy_->SetChildrenNeedBeginFrames(children_need_begin_frames); | 1381 proxy_->SetChildrenNeedBeginFrames(children_need_begin_frames); |
1372 } | 1382 } |
1373 | 1383 |
1374 void LayerTreeHost::SendBeginFramesToChildren( | 1384 void LayerTreeHost::SendBeginFramesToChildren( |
1375 const BeginFrameArgs& args) const { | 1385 const BeginFrameArgs& args) const { |
1376 client_->SendBeginFramesToChildren(args); | 1386 client_->SendBeginFramesToChildren(args); |
1377 } | 1387 } |
1378 | 1388 |
1379 } // namespace cc | 1389 } // namespace cc |
OLD | NEW |