Chromium Code Reviews| Index: cc/resources/picture_pile_base.cc |
| diff --git a/cc/resources/picture_pile_base.cc b/cc/resources/picture_pile_base.cc |
| index 2c87f596c800b708d2e6f3218397b420f1942a31..ee2f51914584442c0bf8a78bdf84d7dd86ac82c3 100644 |
| --- a/cc/resources/picture_pile_base.cc |
| +++ b/cc/resources/picture_pile_base.cc |
| @@ -44,7 +44,8 @@ PicturePileBase::PicturePileBase() |
| slow_down_raster_scale_factor_for_debug_(0), |
| contents_opaque_(false), |
| show_debug_picture_borders_(false), |
| - clear_canvas_with_debug_color_(kDefaultClearCanvasSetting) { |
| + clear_canvas_with_debug_color_(kDefaultClearCanvasSetting), |
| + has_any_recordings_(false) { |
| tiling_.SetMaxTextureSize(gfx::Size(kBasePictureSize, kBasePictureSize)); |
| tile_grid_info_.fTileInterval.setEmpty(); |
| tile_grid_info_.fMargin.setEmpty(); |
| @@ -54,7 +55,7 @@ PicturePileBase::PicturePileBase() |
| PicturePileBase::PicturePileBase(const PicturePileBase* other) |
| : picture_map_(other->picture_map_), |
| tiling_(other->tiling_), |
| - recorded_region_(other->recorded_region_), |
| + recorded_viewport_(other->recorded_viewport_), |
| min_contents_scale_(other->min_contents_scale_), |
| tile_grid_info_(other->tile_grid_info_), |
| background_color_(other->background_color_), |
| @@ -62,13 +63,13 @@ PicturePileBase::PicturePileBase(const PicturePileBase* other) |
| other->slow_down_raster_scale_factor_for_debug_), |
| contents_opaque_(other->contents_opaque_), |
| show_debug_picture_borders_(other->show_debug_picture_borders_), |
| - clear_canvas_with_debug_color_(other->clear_canvas_with_debug_color_) { |
| -} |
| + clear_canvas_with_debug_color_(other->clear_canvas_with_debug_color_), |
| + has_any_recordings_(other->has_any_recordings_) {} |
| -PicturePileBase::PicturePileBase( |
| - const PicturePileBase* other, unsigned thread_index) |
| +PicturePileBase::PicturePileBase(const PicturePileBase* other, |
| + unsigned thread_index) |
| : tiling_(other->tiling_), |
| - recorded_region_(other->recorded_region_), |
| + recorded_viewport_(other->recorded_viewport_), |
| min_contents_scale_(other->min_contents_scale_), |
| tile_grid_info_(other->tile_grid_info_), |
| background_color_(other->background_color_), |
| @@ -76,7 +77,8 @@ PicturePileBase::PicturePileBase( |
| other->slow_down_raster_scale_factor_for_debug_), |
| contents_opaque_(other->contents_opaque_), |
| show_debug_picture_borders_(other->show_debug_picture_borders_), |
| - clear_canvas_with_debug_color_(other->clear_canvas_with_debug_color_) { |
| + clear_canvas_with_debug_color_(other->clear_canvas_with_debug_color_), |
| + has_any_recordings_(other->has_any_recordings_) { |
| for (PictureMap::const_iterator it = other->picture_map_.begin(); |
| it != other->picture_map_.end(); |
| ++it) { |
| @@ -94,6 +96,8 @@ void PicturePileBase::Resize(const gfx::Size& new_size) { |
| gfx::Size old_size = size(); |
| tiling_.SetTotalSize(new_size); |
| + has_any_recordings_ = false; |
| + |
| // Find all tiles that contain any pixels outside the new size. |
| std::vector<PictureMapKey> to_erase; |
| int min_toss_x = tiling_.FirstBorderTileXIndexFromSrcCoord( |
| @@ -104,13 +108,18 @@ void PicturePileBase::Resize(const gfx::Size& new_size) { |
| it != picture_map_.end(); |
| ++it) { |
| const PictureMapKey& key = it->first; |
| - if (key.first < min_toss_x && key.second < min_toss_y) |
| + if (key.first < min_toss_x && key.second < min_toss_y) { |
| + has_any_recordings_ |= !!it->second.GetPicture(); |
| continue; |
| + } |
| to_erase.push_back(key); |
| } |
| for (size_t i = 0; i < to_erase.size(); ++i) |
| picture_map_.erase(to_erase[i]); |
| + |
| + // Don't waste time in Resize figuring out what these hints should be. |
| + recorded_viewport_ = gfx::Rect(); |
| } |
| void PicturePileBase::SetMinContentsScale(float min_contents_scale) { |
| @@ -164,18 +173,7 @@ void PicturePileBase::SetBufferPixels(int new_buffer_pixels) { |
| void PicturePileBase::Clear() { |
| picture_map_.clear(); |
| -} |
| - |
| -void PicturePileBase::UpdateRecordedRegion() { |
| - recorded_region_.Clear(); |
| - for (PictureMap::const_iterator it = picture_map_.begin(); |
| - it != picture_map_.end(); |
| - ++it) { |
| - if (it->second.GetPicture()) { |
| - const PictureMapKey& key = it->first; |
| - recorded_region_.Union(tile_bounds(key.first, key.second)); |
| - } |
| - } |
| + recorded_viewport_ = gfx::Rect(); |
|
enne (OOO)
2014/03/18 00:55:20
This isn't part of the bug, but I just noticed it
vmpstr
2014/03/18 17:24:54
Good catch.
|
| } |
| bool PicturePileBase::HasRecordingAt(int x, int y) { |
| @@ -192,7 +190,30 @@ bool PicturePileBase::CanRaster(float contents_scale, |
| gfx::Rect layer_rect = gfx::ScaleToEnclosingRect( |
| content_rect, 1.f / contents_scale); |
| layer_rect.Intersect(gfx::Rect(tiling_.total_size())); |
| - return recorded_region_.Contains(layer_rect); |
| + |
| + // Common case inside of viewport to avoid the slower map lookups. |
| + if (recorded_viewport_.Contains(layer_rect)) { |
| + // Sanity check that there are no false positives in recorded_viewport_. |
| + DCHECK(CanRasterSlowTileCheck(layer_rect)); |
| + return true; |
| + } |
| + |
| + return CanRasterSlowTileCheck(layer_rect); |
| +} |
| + |
| +bool PicturePileBase::CanRasterSlowTileCheck( |
| + const gfx::Rect& layer_rect) const { |
| + bool include_borders = false; |
|
enne (OOO)
2014/03/18 00:55:20
This is the other half of the bugfix. Later on wh
|
| + for (TilingData::Iterator tile_iter(&tiling_, layer_rect, include_borders); |
| + tile_iter; |
| + ++tile_iter) { |
| + PictureMap::const_iterator map_iter = picture_map_.find(tile_iter.index()); |
| + if (map_iter == picture_map_.end()) |
| + return false; |
| + if (!map_iter->second.GetPicture()) |
| + return false; |
| + } |
| + return true; |
| } |
| gfx::Rect PicturePileBase::PaddedRect(const PictureMapKey& key) { |
| @@ -211,8 +232,10 @@ scoped_ptr<base::Value> PicturePileBase::AsValue() const { |
| scoped_ptr<base::ListValue> pictures(new base::ListValue()); |
| gfx::Rect layer_rect(tiling_.total_size()); |
| std::set<void*> appended_pictures; |
| - for (TilingData::Iterator tile_iter(&tiling_, layer_rect); |
| - tile_iter; ++tile_iter) { |
| + bool include_borders = true; |
| + for (TilingData::Iterator tile_iter(&tiling_, layer_rect, include_borders); |
| + tile_iter; |
| + ++tile_iter) { |
| PictureMap::const_iterator map_iter = picture_map_.find(tile_iter.index()); |
| if (map_iter == picture_map_.end()) |
| continue; |