OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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 "cc/layers/picture_layer_impl.h" | 5 #include "cc/layers/picture_layer_impl.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <limits> | 8 #include <limits> |
9 #include <set> | 9 #include <set> |
10 | 10 |
(...skipping 465 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
476 | 476 |
477 DCHECK(raster_page_scale_); | 477 DCHECK(raster_page_scale_); |
478 DCHECK(raster_device_scale_); | 478 DCHECK(raster_device_scale_); |
479 DCHECK(raster_source_scale_); | 479 DCHECK(raster_source_scale_); |
480 DCHECK(raster_contents_scale_); | 480 DCHECK(raster_contents_scale_); |
481 DCHECK(low_res_raster_contents_scale_); | 481 DCHECK(low_res_raster_contents_scale_); |
482 | 482 |
483 was_screen_space_transform_animating_ = | 483 was_screen_space_transform_animating_ = |
484 draw_properties().screen_space_transform_is_animating; | 484 draw_properties().screen_space_transform_is_animating; |
485 | 485 |
| 486 if (draw_transform_is_animating()) |
| 487 pile_->set_will_be_used_for_transform_animation(true); |
| 488 |
486 should_update_tile_priorities_ = true; | 489 should_update_tile_priorities_ = true; |
487 | 490 |
488 UpdateTilePriorities(occlusion_in_content_space); | 491 UpdateTilePriorities(occlusion_in_content_space); |
489 } | 492 } |
490 | 493 |
491 void PictureLayerImpl::UpdateTilePriorities( | 494 void PictureLayerImpl::UpdateTilePriorities( |
492 const Occlusion& occlusion_in_content_space) { | 495 const Occlusion& occlusion_in_content_space) { |
493 DCHECK(!pile_->is_solid_color() || !tilings_->num_tilings()); | 496 DCHECK(!pile_->is_solid_color() || !tilings_->num_tilings()); |
494 | 497 |
495 TRACE_EVENT0("cc", "PictureLayerImpl::UpdateTilePriorities"); | 498 TRACE_EVENT0("cc", "PictureLayerImpl::UpdateTilePriorities"); |
(...skipping 736 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1232 } | 1235 } |
1233 if (tilings_->num_tilings() == 0) | 1236 if (tilings_->num_tilings() == 0) |
1234 return; | 1237 return; |
1235 | 1238 |
1236 // We should only have one high res tiling. | 1239 // We should only have one high res tiling. |
1237 DCHECK_EQ(1, tilings_->NumHighResTilings()); | 1240 DCHECK_EQ(1, tilings_->NumHighResTilings()); |
1238 #endif | 1241 #endif |
1239 } | 1242 } |
1240 | 1243 |
1241 bool PictureLayerImpl::ShouldAdjustRasterScaleDuringScaleAnimations() const { | 1244 bool PictureLayerImpl::ShouldAdjustRasterScaleDuringScaleAnimations() const { |
1242 if (!layer_tree_impl()->use_gpu_rasterization()) | 1245 return layer_tree_impl()->use_gpu_rasterization(); |
1243 return false; | |
1244 | |
1245 // Re-rastering text at different scales using GPU rasterization causes | |
1246 // texture uploads for glyphs at each scale (see crbug.com/366225). To | |
1247 // workaround this performance issue, we don't re-rasterize layers with | |
1248 // text during scale animations. | |
1249 // TODO(ajuma): Remove this workaround once text can be efficiently | |
1250 // re-rastered at different scales (e.g. by using distance-field fonts). | |
1251 if (pile_->has_text()) | |
1252 return false; | |
1253 | |
1254 return true; | |
1255 } | 1246 } |
1256 | 1247 |
1257 float PictureLayerImpl::MaximumTilingContentsScale() const { | 1248 float PictureLayerImpl::MaximumTilingContentsScale() const { |
1258 float max_contents_scale = MinimumContentsScale(); | 1249 float max_contents_scale = MinimumContentsScale(); |
1259 for (size_t i = 0; i < tilings_->num_tilings(); ++i) { | 1250 for (size_t i = 0; i < tilings_->num_tilings(); ++i) { |
1260 const PictureLayerTiling* tiling = tilings_->tiling_at(i); | 1251 const PictureLayerTiling* tiling = tilings_->tiling_at(i); |
1261 max_contents_scale = std::max(max_contents_scale, tiling->contents_scale()); | 1252 max_contents_scale = std::max(max_contents_scale, tiling->contents_scale()); |
1262 } | 1253 } |
1263 return max_contents_scale; | 1254 return max_contents_scale; |
1264 } | 1255 } |
(...skipping 420 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1685 PictureLayerTilingSet::TilingRange tiling_range = CurrentTilingRange(); | 1676 PictureLayerTilingSet::TilingRange tiling_range = CurrentTilingRange(); |
1686 size_t current_tiling_range_offset = current_tiling_ - tiling_range.start; | 1677 size_t current_tiling_range_offset = current_tiling_ - tiling_range.start; |
1687 return tiling_range.end - 1 - current_tiling_range_offset; | 1678 return tiling_range.end - 1 - current_tiling_range_offset; |
1688 } | 1679 } |
1689 } | 1680 } |
1690 NOTREACHED(); | 1681 NOTREACHED(); |
1691 return 0; | 1682 return 0; |
1692 } | 1683 } |
1693 | 1684 |
1694 } // namespace cc | 1685 } // namespace cc |
OLD | NEW |