| 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/resources/picture_layer_tiling_set.h" | 5 #include "cc/resources/picture_layer_tiling_set.h" |
| 6 | 6 |
| 7 #include <map> | 7 #include <map> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "cc/resources/resource_pool.h" | 10 #include "cc/resources/resource_pool.h" |
| 11 #include "cc/resources/resource_provider.h" | 11 #include "cc/resources/resource_provider.h" |
| 12 #include "cc/test/fake_output_surface.h" | 12 #include "cc/test/fake_output_surface.h" |
| 13 #include "cc/test/fake_output_surface_client.h" | 13 #include "cc/test/fake_output_surface_client.h" |
| 14 #include "cc/test/fake_picture_layer_tiling_client.h" | 14 #include "cc/test/fake_picture_layer_tiling_client.h" |
| 15 #include "cc/test/fake_tile_manager.h" |
| 15 #include "cc/test/fake_tile_manager_client.h" | 16 #include "cc/test/fake_tile_manager_client.h" |
| 16 #include "testing/gtest/include/gtest/gtest.h" | 17 #include "testing/gtest/include/gtest/gtest.h" |
| 17 #include "ui/gfx/size_conversions.h" | 18 #include "ui/gfx/size_conversions.h" |
| 18 | 19 |
| 19 namespace cc { | 20 namespace cc { |
| 20 namespace { | 21 namespace { |
| 21 | 22 |
| 22 TEST(PictureLayerTilingSetTest, NoResources) { | 23 TEST(PictureLayerTilingSetTest, NoResources) { |
| 23 FakePictureLayerTilingClient client; | 24 FakeTileManagerClient tile_manager_client; |
| 25 FakeTileManager tile_manager(&tile_manager_client); |
| 26 FakePictureLayerTilingClient client(&tile_manager); |
| 24 gfx::Size layer_bounds(1000, 800); | 27 gfx::Size layer_bounds(1000, 800); |
| 25 PictureLayerTilingSet set(&client, layer_bounds); | 28 PictureLayerTilingSet set(&client, layer_bounds); |
| 26 client.SetTileSize(gfx::Size(256, 256)); | 29 client.SetTileSize(gfx::Size(256, 256)); |
| 27 | 30 |
| 28 set.AddTiling(1.0); | 31 set.AddTiling(1.0); |
| 29 set.AddTiling(1.5); | 32 set.AddTiling(1.5); |
| 30 set.AddTiling(2.0); | 33 set.AddTiling(2.0); |
| 31 | 34 |
| 32 float contents_scale = 2.0; | 35 float contents_scale = 2.0; |
| 33 gfx::Size content_bounds( | 36 gfx::Size content_bounds( |
| (...skipping 27 matching lines...) Expand all Loading... |
| 61 float ideal_contents_scale, | 64 float ideal_contents_scale, |
| 62 float expected_scale) { | 65 float expected_scale) { |
| 63 FakeOutputSurfaceClient output_surface_client; | 66 FakeOutputSurfaceClient output_surface_client; |
| 64 scoped_ptr<FakeOutputSurface> output_surface = | 67 scoped_ptr<FakeOutputSurface> output_surface = |
| 65 FakeOutputSurface::Create3d(); | 68 FakeOutputSurface::Create3d(); |
| 66 CHECK(output_surface->BindToClient(&output_surface_client)); | 69 CHECK(output_surface->BindToClient(&output_surface_client)); |
| 67 | 70 |
| 68 scoped_ptr<ResourceProvider> resource_provider = | 71 scoped_ptr<ResourceProvider> resource_provider = |
| 69 ResourceProvider::Create(output_surface.get(), NULL, 0, false, 1); | 72 ResourceProvider::Create(output_surface.get(), NULL, 0, false, 1); |
| 70 | 73 |
| 71 FakePictureLayerTilingClient client(resource_provider.get()); | 74 FakeTileManagerClient tile_manager_client; |
| 75 FakeTileManager tile_manager(&tile_manager_client, resource_provider.get()); |
| 76 |
| 77 FakePictureLayerTilingClient client(&tile_manager); |
| 72 client.SetTileSize(gfx::Size(256, 256)); | 78 client.SetTileSize(gfx::Size(256, 256)); |
| 73 gfx::Size layer_bounds(1000, 800); | 79 gfx::Size layer_bounds(1000, 800); |
| 74 PictureLayerTilingSet set(&client, layer_bounds); | 80 PictureLayerTilingSet set(&client, layer_bounds); |
| 75 | 81 |
| 76 float scale = min_scale; | 82 float scale = min_scale; |
| 77 for (int i = 0; i < num_tilings; ++i, scale += scale_increment) { | 83 for (int i = 0; i < num_tilings; ++i, scale += scale_increment) { |
| 78 PictureLayerTiling* tiling = set.AddTiling(scale); | 84 PictureLayerTiling* tiling = set.AddTiling(scale); |
| 79 tiling->CreateAllTilesForTesting(); | 85 tiling->CreateAllTilesForTesting(); |
| 80 std::vector<Tile*> tiles = tiling->AllTilesForTesting(); | 86 std::vector<Tile*> tiles = tiling->AllTilesForTesting(); |
| 81 client.tile_manager()->InitializeTilesWithResourcesForTesting( | 87 client.tile_manager()->InitializeTilesWithResourcesForTesting( |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 143 TEST_F(PictureLayerTilingSetTestWithResources, ManyTilings_NotEqual) { | 149 TEST_F(PictureLayerTilingSetTestWithResources, ManyTilings_NotEqual) { |
| 144 runTest(10, 1.f, 1.f, 4.5f, 5.f); | 150 runTest(10, 1.f, 1.f, 4.5f, 5.f); |
| 145 } | 151 } |
| 146 | 152 |
| 147 class PictureLayerTilingSetSyncTest : public testing::Test { | 153 class PictureLayerTilingSetSyncTest : public testing::Test { |
| 148 public: | 154 public: |
| 149 PictureLayerTilingSetSyncTest() | 155 PictureLayerTilingSetSyncTest() |
| 150 : tile_size_(gfx::Size(10, 10)), | 156 : tile_size_(gfx::Size(10, 10)), |
| 151 source_bounds_(gfx::Size(30, 20)), | 157 source_bounds_(gfx::Size(30, 20)), |
| 152 target_bounds_(gfx::Size(30, 30)) { | 158 target_bounds_(gfx::Size(30, 30)) { |
| 153 source_client_.SetTileSize(tile_size_); | 159 output_surface_ = FakeOutputSurface::Create3d(); |
| 154 target_client_.SetTileSize(tile_size_); | 160 CHECK(output_surface_->BindToClient(&output_surface_client_)); |
| 155 source_.reset(new PictureLayerTilingSet(&source_client_, source_bounds_)); | 161 resource_provider_ = |
| 156 target_.reset(new PictureLayerTilingSet(&target_client_, target_bounds_)); | 162 ResourceProvider::Create(output_surface_.get(), NULL, 0, false, 1); |
| 163 tile_manager_ = make_scoped_ptr( |
| 164 new FakeTileManager(&tile_manager_client_, resource_provider_.get())); |
| 165 source_client_ = |
| 166 make_scoped_ptr(new FakePictureLayerTilingClient(tile_manager_.get())); |
| 167 target_client_ = |
| 168 make_scoped_ptr(new FakePictureLayerTilingClient(tile_manager_.get())); |
| 169 |
| 170 source_client_->SetTileSize(tile_size_); |
| 171 target_client_->SetTileSize(tile_size_); |
| 172 |
| 173 source_.reset( |
| 174 new PictureLayerTilingSet(source_client_.get(), source_bounds_)); |
| 175 target_.reset( |
| 176 new PictureLayerTilingSet(target_client_.get(), target_bounds_)); |
| 157 } | 177 } |
| 158 | 178 |
| 159 // Sync from source to target. | 179 // Sync from source to target. |
| 160 void SyncTilings(gfx::Size new_bounds, | 180 void SyncTilings(gfx::Size new_bounds, |
| 161 const Region& invalidation, | 181 const Region& invalidation, |
| 162 float minimum_scale) { | 182 float minimum_scale) { |
| 163 for (size_t i = 0; i < source_->num_tilings(); ++i) | 183 for (size_t i = 0; i < source_->num_tilings(); ++i) |
| 164 source_->tiling_at(i)->CreateAllTilesForTesting(); | 184 source_->tiling_at(i)->CreateTilesForTesting(ACTIVE_TREE); |
| 165 for (size_t i = 0; i < target_->num_tilings(); ++i) | 185 for (size_t i = 0; i < target_->num_tilings(); ++i) |
| 166 target_->tiling_at(i)->CreateAllTilesForTesting(); | 186 target_->tiling_at(i)->CreateTilesForTesting(PENDING_TREE); |
| 167 | 187 |
| 168 target_->SyncTilings( | 188 target_->SyncTilings( |
| 169 *source_.get(), new_bounds, invalidation, minimum_scale); | 189 *source_.get(), new_bounds, invalidation, minimum_scale); |
| 170 } | 190 } |
| 171 void SyncTilings(gfx::Size new_bounds) { | 191 void SyncTilings(gfx::Size new_bounds) { |
| 172 Region invalidation; | 192 Region invalidation; |
| 173 SyncTilings(new_bounds, invalidation, 0.f); | 193 SyncTilings(new_bounds, invalidation, 0.f); |
| 174 } | 194 } |
| 175 void SyncTilings(gfx::Size new_bounds, const Region& invalidation) { | 195 void SyncTilings(gfx::Size new_bounds, const Region& invalidation) { |
| 176 SyncTilings(new_bounds, invalidation, 0.f); | 196 SyncTilings(new_bounds, invalidation, 0.f); |
| (...skipping 11 matching lines...) Expand all Loading... |
| 188 for (size_t i = 0; i < target_->num_tilings(); ++i) { | 208 for (size_t i = 0; i < target_->num_tilings(); ++i) { |
| 189 ASSERT_GT(source_->num_tilings(), i); | 209 ASSERT_GT(source_->num_tilings(), i); |
| 190 const PictureLayerTiling* source_tiling = source_->tiling_at(i); | 210 const PictureLayerTiling* source_tiling = source_->tiling_at(i); |
| 191 const PictureLayerTiling* target_tiling = target_->tiling_at(i); | 211 const PictureLayerTiling* target_tiling = target_->tiling_at(i); |
| 192 EXPECT_EQ(target_tiling->layer_bounds().ToString(), | 212 EXPECT_EQ(target_tiling->layer_bounds().ToString(), |
| 193 new_bounds.ToString()); | 213 new_bounds.ToString()); |
| 194 EXPECT_EQ(source_tiling->contents_scale(), | 214 EXPECT_EQ(source_tiling->contents_scale(), |
| 195 target_tiling->contents_scale()); | 215 target_tiling->contents_scale()); |
| 196 } | 216 } |
| 197 | 217 |
| 198 EXPECT_EQ(source_->client(), &source_client_); | 218 EXPECT_EQ(source_->client(), source_client_.get()); |
| 199 EXPECT_EQ(target_->client(), &target_client_); | 219 EXPECT_EQ(target_->client(), target_client_.get()); |
| 200 ValidateTargetTilingSet(); | 220 ValidateTargetTilingSet(); |
| 201 } | 221 } |
| 202 | 222 |
| 203 void ValidateTargetTilingSet() const { | 223 void ValidateTargetTilingSet() const { |
| 204 // Tilings should be sorted largest to smallest. | 224 // Tilings should be sorted largest to smallest. |
| 205 if (target_->num_tilings() > 0) { | 225 if (target_->num_tilings() > 0) { |
| 206 float last_scale = target_->tiling_at(0)->contents_scale(); | 226 float last_scale = target_->tiling_at(0)->contents_scale(); |
| 207 for (size_t i = 1; i < target_->num_tilings(); ++i) { | 227 for (size_t i = 1; i < target_->num_tilings(); ++i) { |
| 208 const PictureLayerTiling* target_tiling = target_->tiling_at(i); | 228 const PictureLayerTiling* target_tiling = target_->tiling_at(i); |
| 209 EXPECT_LT(target_tiling->contents_scale(), last_scale); | 229 EXPECT_LT(target_tiling->contents_scale(), last_scale); |
| 210 last_scale = target_tiling->contents_scale(); | 230 last_scale = target_tiling->contents_scale(); |
| 211 } | 231 } |
| 212 } | 232 } |
| 213 | 233 |
| 214 for (size_t i = 0; i < target_->num_tilings(); ++i) | 234 for (size_t i = 0; i < target_->num_tilings(); ++i) |
| 215 ValidateTiling(target_->tiling_at(i), target_client_.pile()); | 235 ValidateTiling(target_->tiling_at(i), target_client_->pile()); |
| 216 } | 236 } |
| 217 | 237 |
| 218 void ValidateTiling(const PictureLayerTiling* tiling, | 238 void ValidateTiling(const PictureLayerTiling* tiling, |
| 219 const PicturePileImpl* pile) const { | 239 const PicturePileImpl* pile) const { |
| 220 if (tiling->ContentRect().IsEmpty()) | 240 if (tiling->ContentRect().IsEmpty()) |
| 221 EXPECT_TRUE(tiling->live_tiles_rect().IsEmpty()); | 241 EXPECT_TRUE(tiling->live_tiles_rect().IsEmpty()); |
| 222 else if (!tiling->live_tiles_rect().IsEmpty()) | 242 else if (!tiling->live_tiles_rect().IsEmpty()) |
| 223 EXPECT_TRUE(tiling->ContentRect().Contains(tiling->live_tiles_rect())); | 243 EXPECT_TRUE(tiling->ContentRect().Contains(tiling->live_tiles_rect())); |
| 224 | 244 |
| 225 std::vector<Tile*> tiles = tiling->AllTilesForTesting(); | 245 std::vector<Tile*> tiles = tiling->TilesForTesting(PENDING_TREE); |
| 226 for (size_t i = 0; i < tiles.size(); ++i) { | 246 for (size_t i = 0; i < tiles.size(); ++i) { |
| 227 const Tile* tile = tiles[i]; | 247 const Tile* tile = tiles[i]; |
| 228 ASSERT_TRUE(!!tile); | 248 ASSERT_TRUE(!!tile); |
| 229 EXPECT_EQ(tile->picture_pile(), pile); | 249 EXPECT_EQ(tile->picture_pile(), pile); |
| 230 EXPECT_TRUE(tile->content_rect().Intersects(tiling->live_tiles_rect())) | 250 EXPECT_TRUE(tile->content_rect().Intersects(tiling->live_tiles_rect())) |
| 231 << "All tiles must be inside the live tiles rect."; | 251 << "All tiles must be inside the live tiles rect."; |
| 232 } | 252 } |
| 233 | 253 |
| 234 for (PictureLayerTiling::CoverageIterator iter( | 254 for (PictureLayerTiling::CoverageIterator iter( |
| 235 tiling, tiling->contents_scale(), tiling->live_tiles_rect()); | 255 tiling, tiling->contents_scale(), tiling->live_tiles_rect()); |
| 236 iter; | 256 iter; |
| 237 ++iter) { | 257 ++iter) { |
| 238 EXPECT_TRUE(*iter) << "The live tiles rect must be full."; | 258 EXPECT_TRUE(*iter) << "The live tiles rect must be full."; |
| 239 } | 259 } |
| 240 } | 260 } |
| 241 | 261 |
| 262 scoped_ptr<FakeOutputSurface> output_surface_; |
| 263 FakeOutputSurfaceClient output_surface_client_; |
| 264 |
| 242 gfx::Size tile_size_; | 265 gfx::Size tile_size_; |
| 266 scoped_ptr<ResourceProvider> resource_provider_; |
| 267 scoped_ptr<FakeTileManager> tile_manager_; |
| 268 FakeTileManagerClient tile_manager_client_; |
| 243 | 269 |
| 244 FakePictureLayerTilingClient source_client_; | 270 scoped_ptr<FakePictureLayerTilingClient> source_client_; |
| 245 gfx::Size source_bounds_; | 271 gfx::Size source_bounds_; |
| 246 scoped_ptr<PictureLayerTilingSet> source_; | 272 scoped_ptr<PictureLayerTilingSet> source_; |
| 247 | 273 |
| 248 FakePictureLayerTilingClient target_client_; | 274 scoped_ptr<FakePictureLayerTilingClient> target_client_; |
| 249 gfx::Size target_bounds_; | 275 gfx::Size target_bounds_; |
| 250 scoped_ptr<PictureLayerTilingSet> target_; | 276 scoped_ptr<PictureLayerTilingSet> target_; |
| 251 }; | 277 }; |
| 252 | 278 |
| 253 TEST_F(PictureLayerTilingSetSyncTest, EmptyBounds) { | 279 TEST_F(PictureLayerTilingSetSyncTest, EmptyBounds) { |
| 254 float source_scales[] = {1.f, 1.2f}; | 280 float source_scales[] = {1.f, 1.2f}; |
| 255 for (size_t i = 0; i < arraysize(source_scales); ++i) | 281 for (size_t i = 0; i < arraysize(source_scales); ++i) |
| 256 source_->AddTiling(source_scales[i]); | 282 source_->AddTiling(source_scales[i]); |
| 257 | 283 |
| 258 gfx::Size new_bounds; | 284 gfx::Size new_bounds; |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 341 SyncTilings(new_bounds, minimum_scale); | 367 SyncTilings(new_bounds, minimum_scale); |
| 342 | 368 |
| 343 EXPECT_EQ(target_->num_tilings(), 1u); | 369 EXPECT_EQ(target_->num_tilings(), 1u); |
| 344 EXPECT_EQ(target_->tiling_at(0)->contents_scale(), 2.f); | 370 EXPECT_EQ(target_->tiling_at(0)->contents_scale(), 2.f); |
| 345 ValidateTargetTilingSet(); | 371 ValidateTargetTilingSet(); |
| 346 } | 372 } |
| 347 | 373 |
| 348 TEST_F(PictureLayerTilingSetSyncTest, Invalidation) { | 374 TEST_F(PictureLayerTilingSetSyncTest, Invalidation) { |
| 349 source_->AddTiling(2.f); | 375 source_->AddTiling(2.f); |
| 350 target_->AddTiling(2.f); | 376 target_->AddTiling(2.f); |
| 351 target_->tiling_at(0)->CreateAllTilesForTesting(); | 377 target_->tiling_at(0)->CreateTilesForTesting(PENDING_TREE); |
| 352 | 378 |
| 353 Region layer_invalidation; | 379 Region layer_invalidation; |
| 354 layer_invalidation.Union(gfx::Rect(0, 0, 1, 1)); | 380 layer_invalidation.Union(gfx::Rect(0, 0, 1, 1)); |
| 355 layer_invalidation.Union(gfx::Rect(0, 15, 1, 1)); | 381 layer_invalidation.Union(gfx::Rect(0, 15, 1, 1)); |
| 356 // Out of bounds layer_invalidation. | 382 // Out of bounds layer_invalidation. |
| 357 layer_invalidation.Union(gfx::Rect(100, 100, 1, 1)); | 383 layer_invalidation.Union(gfx::Rect(100, 100, 1, 1)); |
| 358 | 384 |
| 359 Region content_invalidation; | 385 Region content_invalidation; |
| 360 for (Region::Iterator iter(layer_invalidation); iter.has_rect(); | 386 for (Region::Iterator iter(layer_invalidation); iter.has_rect(); |
| 361 iter.next()) { | 387 iter.next()) { |
| (...skipping 23 matching lines...) Expand all Loading... |
| 385 | 411 |
| 386 TEST_F(PictureLayerTilingSetSyncTest, TileSizeChange) { | 412 TEST_F(PictureLayerTilingSetSyncTest, TileSizeChange) { |
| 387 source_->AddTiling(1.f); | 413 source_->AddTiling(1.f); |
| 388 target_->AddTiling(1.f); | 414 target_->AddTiling(1.f); |
| 389 | 415 |
| 390 target_->tiling_at(0)->CreateAllTilesForTesting(); | 416 target_->tiling_at(0)->CreateAllTilesForTesting(); |
| 391 std::vector<Tile*> original_tiles = | 417 std::vector<Tile*> original_tiles = |
| 392 target_->tiling_at(0)->AllTilesForTesting(); | 418 target_->tiling_at(0)->AllTilesForTesting(); |
| 393 EXPECT_GT(original_tiles.size(), 0u); | 419 EXPECT_GT(original_tiles.size(), 0u); |
| 394 gfx::Size new_tile_size(100, 100); | 420 gfx::Size new_tile_size(100, 100); |
| 395 target_client_.SetTileSize(new_tile_size); | 421 target_client_->SetTileSize(new_tile_size); |
| 396 EXPECT_NE(target_->tiling_at(0)->tile_size().ToString(), | 422 EXPECT_NE(target_->tiling_at(0)->tile_size().ToString(), |
| 397 new_tile_size.ToString()); | 423 new_tile_size.ToString()); |
| 398 | 424 |
| 399 gfx::Size new_bounds(15, 40); | 425 gfx::Size new_bounds(15, 40); |
| 400 SyncTilings(new_bounds); | 426 SyncTilings(new_bounds); |
| 401 VerifyTargetEqualsSource(new_bounds); | 427 VerifyTargetEqualsSource(new_bounds); |
| 402 | 428 |
| 403 EXPECT_EQ(target_->tiling_at(0)->tile_size().ToString(), | 429 EXPECT_EQ(target_->tiling_at(0)->tile_size().ToString(), |
| 404 new_tile_size.ToString()); | 430 new_tile_size.ToString()); |
| 405 | 431 |
| 406 // All old tiles should not be present in new tiles. | 432 // All old tiles should not be present in new tiles. |
| 407 std::vector<Tile*> new_tiles = target_->tiling_at(0)->AllTilesForTesting(); | 433 std::vector<Tile*> new_tiles = target_->tiling_at(0)->AllTilesForTesting(); |
| 408 for (size_t i = 0; i < original_tiles.size(); ++i) { | 434 for (size_t i = 0; i < original_tiles.size(); ++i) { |
| 409 std::vector<Tile*>::iterator find = | 435 std::vector<Tile*>::iterator find = |
| 410 std::find(new_tiles.begin(), new_tiles.end(), original_tiles[i]); | 436 std::find(new_tiles.begin(), new_tiles.end(), original_tiles[i]); |
| 411 EXPECT_TRUE(find == new_tiles.end()); | 437 EXPECT_TRUE(find == new_tiles.end()); |
| 412 } | 438 } |
| 413 } | 439 } |
| 414 | 440 |
| 415 } // namespace | 441 } // namespace |
| 416 } // namespace cc | 442 } // namespace cc |
| OLD | NEW |