Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(762)

Unified Diff: cc/resources/picture_layer_tiling_unittest.cc

Issue 13895005: cc: Find a better prioritized rect when the viewport rect is huge. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: cc/resources/picture_layer_tiling_unittest.cc
diff --git a/cc/resources/picture_layer_tiling_unittest.cc b/cc/resources/picture_layer_tiling_unittest.cc
index 5e29b826275064786933a743a10812754c712c7c..6f3a822f82eb40cbfb3e676e41f9f901122a87fa 100644
--- a/cc/resources/picture_layer_tiling_unittest.cc
+++ b/cc/resources/picture_layer_tiling_unittest.cc
@@ -421,6 +421,7 @@ TEST_F(PictureLayerTilingIteratorTest, TilesExist) {
ACTIVE_TREE,
layer_bounds, // device viewport
gfx::Rect(layer_bounds), // viewport in layer space
+ gfx::Rect(layer_bounds), // visible content rect
layer_bounds, // last layer bounds
layer_bounds, // current layer bounds
1.f, // last contents scale
@@ -438,6 +439,7 @@ TEST_F(PictureLayerTilingIteratorTest, TilesExist) {
ACTIVE_TREE,
layer_bounds, // device viewport
gfx::Rect(), // viewport in layer space
+ gfx::Rect(), // visible content rect
layer_bounds, // last layer bounds
layer_bounds, // current layer bounds
1.f, // last contents scale
@@ -451,5 +453,78 @@ TEST_F(PictureLayerTilingIteratorTest, TilesExist) {
VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, false));
}
+TEST_F(PictureLayerTilingIteratorTest, TilesExistGiantViewport) {
+ gfx::Size layer_bounds(1099, 801);
+ Initialize(gfx::Size(100, 100), 1.f, layer_bounds);
+ VerifyTilesExactlyCoverRect(1.f, gfx::Rect(layer_bounds));
+ VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, false));
+
+ gfx::Rect giant_rect(-10000000, -10000000, 1000000000, 1000000000);
+
+ tiling_->UpdateTilePriorities(
+ ACTIVE_TREE,
+ layer_bounds, // device viewport
+ giant_rect, // viewport in layer space
+ gfx::Rect(layer_bounds), // visible content rect
+ layer_bounds, // last layer bounds
+ layer_bounds, // current layer bounds
+ 1.f, // last contents scale
+ 1.f, // current contents scale
+ gfx::Transform(), // last screen transform
+ gfx::Transform(), // current screen transform
+ 1, // current frame number
+ 1.0, // current frame time
+ false, // store screen space quads on tiles
+ 10000); // max tiles in tile manager
+ VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, true));
+
+ // If the visible content rect is empty, it should still have live tiles.
+ tiling_->UpdateTilePriorities(
+ ACTIVE_TREE,
+ layer_bounds, // device viewport
+ giant_rect, // viewport in layer space
+ gfx::Rect(), // visible content rect
+ layer_bounds, // last layer bounds
+ layer_bounds, // current layer bounds
+ 1.f, // last contents scale
+ 1.f, // current contents scale
+ gfx::Transform(), // last screen transform
+ gfx::Transform(), // current screen transform
+ 2, // current frame number
+ 2.0, // current frame time
+ false, // store screen space quads on tiles
+ 10000); // max tiles in tile manager
+ VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, true));
+}
+
+TEST_F(PictureLayerTilingIteratorTest, TilesExistOutsideViewport) {
+ gfx::Size layer_bounds(1099, 801);
+ Initialize(gfx::Size(100, 100), 1.f, layer_bounds);
+ VerifyTilesExactlyCoverRect(1.f, gfx::Rect(layer_bounds));
+ VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, false));
+
+ // This rect does not intersect with the layer, as the layer is outside the
+ // viewport.
+ gfx::Rect viewport_rect(1100, 0, 1000, 1000);
+ EXPECT_FALSE(viewport_rect.Intersects(gfx::Rect(layer_bounds)));
+
+ tiling_->UpdateTilePriorities(
+ ACTIVE_TREE,
+ layer_bounds, // device viewport
+ viewport_rect, // viewport in layer space
+ gfx::Rect(), // visible content rect
+ layer_bounds, // last layer bounds
+ layer_bounds, // current layer bounds
+ 1.f, // last contents scale
+ 1.f, // current contents scale
+ gfx::Transform(), // last screen transform
+ gfx::Transform(), // current screen transform
+ 2, // current frame number
+ 2.0, // current frame time
+ false, // store screen space quads on tiles
+ 10000); // max tiles in tile manager
+ VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, true));
+}
+
} // namespace
} // namespace cc
« cc/resources/picture_layer_tiling.cc ('K') | « cc/resources/picture_layer_tiling_set.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698