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_impl.h" | 5 #include "cc/trees/layer_tree_impl.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 | 9 |
10 #include <algorithm> | 10 #include <algorithm> |
(...skipping 224 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
235 return; | 235 return; |
236 | 236 |
237 gfx::ScrollOffset current_offset = scroll_layer->CurrentScrollOffset(); | 237 gfx::ScrollOffset current_offset = scroll_layer->CurrentScrollOffset(); |
238 if (IsViewportLayerId(scroll_layer_id)) { | 238 if (IsViewportLayerId(scroll_layer_id)) { |
239 current_offset += InnerViewportScrollLayer()->CurrentScrollOffset(); | 239 current_offset += InnerViewportScrollLayer()->CurrentScrollOffset(); |
240 if (OuterViewportContainerLayer()) | 240 if (OuterViewportContainerLayer()) |
241 clip_size.SetToMin(OuterViewportContainerLayer()->BoundsForScrolling()); | 241 clip_size.SetToMin(OuterViewportContainerLayer()->BoundsForScrolling()); |
242 clip_size.Scale(1 / current_page_scale_factor()); | 242 clip_size.Scale(1 / current_page_scale_factor()); |
243 } | 243 } |
244 | 244 |
245 bool scrollbar_needs_animation = false; | |
246 bool clip_layer_size_did_change = false; | |
247 bool scroll_layer_size_did_change = false; | |
248 bool y_offset_did_change = false; | 245 bool y_offset_did_change = false; |
249 for (auto* scrollbar : ScrollbarsFor(scroll_layer->element_id())) { | 246 for (auto* scrollbar : ScrollbarsFor(scroll_layer->element_id())) { |
250 if (scrollbar->orientation() == HORIZONTAL) { | 247 if (scrollbar->orientation() == HORIZONTAL) { |
251 scrollbar_needs_animation |= scrollbar->SetCurrentPos(current_offset.x()); | 248 scrollbar->SetCurrentPos(current_offset.x()); |
252 clip_layer_size_did_change |= | 249 scrollbar->SetClipLayerLength(clip_size.width()); |
253 scrollbar->SetClipLayerLength(clip_size.width()); | 250 scrollbar->SetScrollLayerLength(scroll_size.width()); |
254 scroll_layer_size_did_change |= | |
255 scrollbar->SetScrollLayerLength(scroll_size.width()); | |
256 } else { | 251 } else { |
257 scrollbar_needs_animation |= y_offset_did_change |= | 252 y_offset_did_change = scrollbar->SetCurrentPos(current_offset.y()); |
258 scrollbar->SetCurrentPos(current_offset.y()); | 253 scrollbar->SetClipLayerLength(clip_size.height()); |
259 clip_layer_size_did_change |= | 254 scrollbar->SetScrollLayerLength(scroll_size.height()); |
260 scrollbar->SetClipLayerLength(clip_size.height()); | |
261 scroll_layer_size_did_change |= | |
262 scrollbar->SetScrollLayerLength(scroll_size.height()); | |
263 } | 255 } |
264 scrollbar_needs_animation |= | 256 scrollbar->SetVerticalAdjust(clip_layer->bounds_delta().y()); |
265 scrollbar->SetVerticalAdjust(clip_layer->bounds_delta().y()); | |
266 } | 257 } |
267 | 258 |
268 scrollbar_needs_animation |= | |
269 (clip_layer_size_did_change || scroll_layer_size_did_change); | |
270 | |
271 if (y_offset_did_change && IsViewportLayerId(scroll_layer_id)) | 259 if (y_offset_did_change && IsViewportLayerId(scroll_layer_id)) |
272 TRACE_COUNTER_ID1("cc", "scroll_offset_y", scroll_layer->id(), | 260 TRACE_COUNTER_ID1("cc", "scroll_offset_y", scroll_layer->id(), |
273 current_offset.y()); | 261 current_offset.y()); |
274 | |
275 if (scrollbar_needs_animation) { | |
276 ScrollbarAnimationController* controller = | |
277 layer_tree_host_impl_->ScrollbarAnimationControllerForElementId( | |
278 scroll_layer->element_id()); | |
279 if (!controller) | |
280 return; | |
281 | |
282 // TODO(chaopeng) clip_layer_size_did_change should call DidResize after | |
283 // crbug.com/701810 got fixed. | |
284 if (scroll_layer_size_did_change) { | |
285 controller->DidResize(); | |
286 } else { | |
287 controller->DidScrollUpdate(); | |
288 } | |
289 } | |
290 } | 262 } |
291 | 263 |
292 RenderSurfaceImpl* LayerTreeImpl::RootRenderSurface() const { | 264 RenderSurfaceImpl* LayerTreeImpl::RootRenderSurface() const { |
293 return layer_list_.empty() ? nullptr : layer_list_[0]->GetRenderSurface(); | 265 return layer_list_.empty() ? nullptr : layer_list_[0]->GetRenderSurface(); |
294 } | 266 } |
295 | 267 |
296 bool LayerTreeImpl::LayerListIsEmpty() const { | 268 bool LayerTreeImpl::LayerListIsEmpty() const { |
297 return layer_list_.empty(); | 269 return layer_list_.empty(); |
298 } | 270 } |
299 | 271 |
(...skipping 658 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
958 return true; | 930 return true; |
959 } | 931 } |
960 | 932 |
961 void LayerTreeImpl::DidUpdatePageScale() { | 933 void LayerTreeImpl::DidUpdatePageScale() { |
962 if (IsActiveTree()) | 934 if (IsActiveTree()) |
963 page_scale_factor()->SetCurrent( | 935 page_scale_factor()->SetCurrent( |
964 ClampPageScaleFactorToLimits(current_page_scale_factor())); | 936 ClampPageScaleFactorToLimits(current_page_scale_factor())); |
965 | 937 |
966 set_needs_update_draw_properties(); | 938 set_needs_update_draw_properties(); |
967 DidUpdateScrollState(inner_viewport_scroll_layer_id_); | 939 DidUpdateScrollState(inner_viewport_scroll_layer_id_); |
940 | |
941 if (IsActiveTree() && OuterViewportScrollLayer()) { | |
bokan
2017/04/25 22:56:48
Use LTHI::ViewportMainScrollLayer rather than Oute
skobes
2017/04/27 00:46:31
Done.
| |
942 if (ScrollbarAnimationController* controller = | |
943 layer_tree_host_impl_->ScrollbarAnimationControllerForElementId( | |
944 OuterViewportScrollLayer()->element_id())) | |
945 controller->DidScrollUpdate(); | |
946 } | |
968 } | 947 } |
969 | 948 |
970 void LayerTreeImpl::SetDeviceScaleFactor(float device_scale_factor) { | 949 void LayerTreeImpl::SetDeviceScaleFactor(float device_scale_factor) { |
971 if (device_scale_factor == device_scale_factor_) | 950 if (device_scale_factor == device_scale_factor_) |
972 return; | 951 return; |
973 device_scale_factor_ = device_scale_factor; | 952 device_scale_factor_ = device_scale_factor; |
974 | 953 |
975 set_needs_update_draw_properties(); | 954 set_needs_update_draw_properties(); |
976 if (IsActiveTree()) | 955 if (IsActiveTree()) |
977 layer_tree_host_impl_->SetFullViewportDamage(); | 956 layer_tree_host_impl_->SetFullViewportDamage(); |
(...skipping 1200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2178 | 2157 |
2179 void LayerTreeImpl::ResetAllChangeTracking() { | 2158 void LayerTreeImpl::ResetAllChangeTracking() { |
2180 layers_that_should_push_properties_.clear(); | 2159 layers_that_should_push_properties_.clear(); |
2181 // Iterate over all layers, including masks. | 2160 // Iterate over all layers, including masks. |
2182 for (auto& layer : *layers_) | 2161 for (auto& layer : *layers_) |
2183 layer->ResetChangeTracking(); | 2162 layer->ResetChangeTracking(); |
2184 property_trees_.ResetAllChangeTracking(); | 2163 property_trees_.ResetAllChangeTracking(); |
2185 } | 2164 } |
2186 | 2165 |
2187 } // namespace cc | 2166 } // namespace cc |
OLD | NEW |