Index: cc/resources/picture_pile_base.cc |
diff --git a/cc/resources/picture_pile_base.cc b/cc/resources/picture_pile_base.cc |
index 2fb6ef5b84a282b1b90f36affe1c2eed68df6492..aa00876f7882f6d338f7b3f2751ceb2a79e14b5c 100644 |
--- a/cc/resources/picture_pile_base.cc |
+++ b/cc/resources/picture_pile_base.cc |
@@ -92,21 +92,29 @@ PicturePileBase::PicturePileBase(const PicturePileBase* other, |
PicturePileBase::~PicturePileBase() { |
} |
-void PicturePileBase::Resize(const gfx::Size& new_size) { |
- if (size() == new_size) |
+void PicturePileBase::SetTilingRect(const gfx::Rect& new_tiling_rect) { |
+ if (tiling_rect() == new_tiling_rect) |
return; |
- gfx::Size old_size = size(); |
- tiling_.SetTotalSize(new_size); |
+ gfx::Rect old_tiling_rect = tiling_rect(); |
+ tiling_.SetTilingRect(new_tiling_rect); |
has_any_recordings_ = false; |
- // Find all tiles that contain any pixels outside the new size. |
+ // Don't waste time in Resize figuring out what these hints should be. |
+ recorded_viewport_ = gfx::Rect(); |
+ |
+ if (new_tiling_rect.origin() != old_tiling_rect.origin()) { |
+ picture_map_.clear(); |
+ return; |
+ } |
+ |
+ // Find all tiles that contain any pixels outside the new rect. |
std::vector<PictureMapKey> to_erase; |
int min_toss_x = tiling_.FirstBorderTileXIndexFromSrcCoord( |
- std::min(old_size.width(), new_size.width())); |
+ std::min(old_tiling_rect.right(), new_tiling_rect.right())); |
int min_toss_y = tiling_.FirstBorderTileYIndexFromSrcCoord( |
- std::min(old_size.height(), new_size.height())); |
+ std::min(old_tiling_rect.bottom(), new_tiling_rect.bottom())); |
for (PictureMap::const_iterator it = picture_map_.begin(); |
it != picture_map_.end(); |
++it) { |
@@ -120,9 +128,6 @@ void PicturePileBase::Resize(const gfx::Size& new_size) { |
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) { |
@@ -188,11 +193,11 @@ bool PicturePileBase::HasRecordingAt(int x, int y) { |
bool PicturePileBase::CanRaster(float contents_scale, |
const gfx::Rect& content_rect) { |
- if (tiling_.total_size().IsEmpty()) |
+ if (tiling_.tiling_rect().IsEmpty()) |
return false; |
gfx::Rect layer_rect = gfx::ScaleToEnclosingRect( |
content_rect, 1.f / contents_scale); |
- layer_rect.Intersect(gfx::Rect(tiling_.total_size())); |
+ layer_rect.Intersect(tiling_.tiling_rect()); |
// Common case inside of viewport to avoid the slower map lookups. |
if (recorded_viewport_.Contains(layer_rect)) { |
@@ -233,10 +238,10 @@ gfx::Rect PicturePileBase::PadRect(const gfx::Rect& rect) { |
scoped_ptr<base::Value> PicturePileBase::AsValue() const { |
scoped_ptr<base::ListValue> pictures(new base::ListValue()); |
- gfx::Rect layer_rect(tiling_.total_size()); |
+ gfx::Rect tiling_rect(tiling_.tiling_rect()); |
std::set<void*> appended_pictures; |
bool include_borders = true; |
- for (TilingData::Iterator tile_iter(&tiling_, layer_rect, include_borders); |
+ for (TilingData::Iterator tile_iter(&tiling_, tiling_rect, include_borders); |
tile_iter; |
++tile_iter) { |
PictureMap::const_iterator map_iter = picture_map_.find(tile_iter.index()); |