summaryrefslogtreecommitdiffstats
path: root/cc/test/fake_picture_pile_impl.cc
diff options
context:
space:
mode:
authorenne@chromium.org <enne@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-03-19 05:46:33 +0000
committerenne@chromium.org <enne@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-03-19 05:46:33 +0000
commit62b6fdb8d49e80c053fc6dd38548b933ba668e83 (patch)
tree0c993df7d943ab20d5a7c28f46481dec95381ff5 /cc/test/fake_picture_pile_impl.cc
parente34c0be97a60b56390e598ca34a1da7e81a8b2a7 (diff)
downloadchromium_src-62b6fdb8d49e80c053fc6dd38548b933ba668e83.zip
chromium_src-62b6fdb8d49e80c053fc6dd38548b933ba668e83.tar.gz
chromium_src-62b6fdb8d49e80c053fc6dd38548b933ba668e83.tar.bz2
cc: Replace recorded region with direct map lookup
If the viewport is extremely large, then keeping track of the recorded region in PicturePile with an actual Region becomes extremely slow due to a large number of rects being inserted into it. The recorded region behaves as a cache to the picture map; it's a simpler way to know the state of all of the recordings contained within. In practice, the recorded region is only used for two things: a "should this pile bother to create tilings" optimization and a "can a tile be rastered in this content rect" check aka CanRaster. The optimization for "should create tilings" is replaced by a has_any_recordings_ boolean, which could have a false positive in theory (resizing to a smaller but non-empty size), but which shouldn't happen in practice. Even if it did, this would only be a performance penalty for creating no-op tilings that can't create tiles (due to CanRaster). The CanRaster check is replaced by a viewport hint, as most tiles that the tiling creates will be inside of the very large expanded viewport during recording, turning an expensive Region.Contains check to a Rect.Contains one. In the edge cases where tiles are being created outside of that expanded viewport, it will check the picture map directly. This should only happen when the user has scrolled thousands of pixels without a commit. BUG=353346 Committed: https://src.chromium.org/viewvc/chrome?view=rev&revision=256953 Review URL: https://codereview.chromium.org/196343005 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@257852 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'cc/test/fake_picture_pile_impl.cc')
-rw-r--r--cc/test/fake_picture_pile_impl.cc29
1 files changed, 18 insertions, 11 deletions
diff --git a/cc/test/fake_picture_pile_impl.cc b/cc/test/fake_picture_pile_impl.cc
index bb60034..4bcf4b0 100644
--- a/cc/test/fake_picture_pile_impl.cc
+++ b/cc/test/fake_picture_pile_impl.cc
@@ -23,11 +23,12 @@ scoped_refptr<FakePicturePileImpl> FakePicturePileImpl::CreateFilledPile(
pile->tiling().SetTotalSize(layer_bounds);
pile->tiling().SetMaxTextureSize(tile_size);
pile->SetTileGridSize(ImplSidePaintingSettings().default_tile_size);
+ pile->recorded_viewport_ = gfx::Rect(layer_bounds);
+ pile->has_any_recordings_ = true;
for (int x = 0; x < pile->tiling().num_tiles_x(); ++x) {
for (int y = 0; y < pile->tiling().num_tiles_y(); ++y)
pile->AddRecordingAt(x, y);
}
- pile->UpdateRecordedRegion();
return pile;
}
@@ -38,29 +39,37 @@ scoped_refptr<FakePicturePileImpl> FakePicturePileImpl::CreateEmptyPile(
pile->tiling().SetTotalSize(layer_bounds);
pile->tiling().SetMaxTextureSize(tile_size);
pile->SetTileGridSize(ImplSidePaintingSettings().default_tile_size);
- pile->UpdateRecordedRegion();
+ pile->recorded_viewport_ = gfx::Rect();
+ pile->has_any_recordings_ = false;
return pile;
}
scoped_refptr<FakePicturePileImpl>
-FakePicturePileImpl::CreatePileWithRecordedRegion(
+FakePicturePileImpl::CreateEmptyPileThatThinksItHasRecordings(
const gfx::Size& tile_size,
- const gfx::Size& layer_bounds,
- const Region& recorded_region) {
+ const gfx::Size& layer_bounds) {
scoped_refptr<FakePicturePileImpl> pile(new FakePicturePileImpl());
pile->tiling().SetTotalSize(layer_bounds);
pile->tiling().SetMaxTextureSize(tile_size);
pile->SetTileGridSize(ImplSidePaintingSettings().default_tile_size);
- pile->SetRecordedRegionForTesting(recorded_region);
+ // This simulates a false positive for this flag.
+ pile->recorded_viewport_ = gfx::Rect();
+ pile->has_any_recordings_ = true;
return pile;
}
-scoped_refptr<FakePicturePileImpl> FakePicturePileImpl::CreatePile() {
+scoped_refptr<FakePicturePileImpl>
+FakePicturePileImpl::CreateInfiniteFilledPile() {
scoped_refptr<FakePicturePileImpl> pile(new FakePicturePileImpl());
gfx::Size size(std::numeric_limits<int>::max(),
std::numeric_limits<int>::max());
pile->Resize(size);
- pile->recorded_region_ = Region(gfx::Rect(size));
+ pile->tiling().SetTotalSize(size);
+ pile->tiling().SetMaxTextureSize(size);
+ pile->SetTileGridSize(size);
+ pile->recorded_viewport_ = gfx::Rect(size);
+ pile->has_any_recordings_ = true;
+ pile->AddRecordingAt(0, 0);
return pile;
}
@@ -80,7 +89,7 @@ void FakePicturePileImpl::AddRecordingAt(int x, int y) {
picture_map_[std::pair<int, int>(x, y)].SetPicture(picture);
EXPECT_TRUE(HasRecordingAt(x, y));
- UpdateRecordedRegion();
+ has_any_recordings_ = true;
}
void FakePicturePileImpl::RemoveRecordingAt(int x, int y) {
@@ -93,8 +102,6 @@ void FakePicturePileImpl::RemoveRecordingAt(int x, int y) {
return;
picture_map_.erase(std::pair<int, int>(x, y));
EXPECT_FALSE(HasRecordingAt(x, y));
-
- UpdateRecordedRegion();
}
void FakePicturePileImpl::RerecordPile() {