| 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 |