| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 <stddef.h> | 5 #include <stddef.h> |
| 6 | 6 |
| 7 #include "base/memory/scoped_ptr.h" | 7 #include "base/memory/scoped_ptr.h" |
| 8 #include "cc/playback/raster_source.h" | 8 #include "cc/playback/raster_source.h" |
| 9 #include "cc/test/fake_recording_source.h" | 9 #include "cc/test/fake_recording_source.h" |
| 10 #include "cc/test/skia_common.h" | 10 #include "cc/test/skia_common.h" |
| (...skipping 267 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 278 // up to one pixel outside the content rect is guaranteed to be opaque. | 278 // up to one pixel outside the content rect is guaranteed to be opaque. |
| 279 // Outside of that is undefined. | 279 // Outside of that is undefined. |
| 280 gfx::Rect canvas_rect(content_rect); | 280 gfx::Rect canvas_rect(content_rect); |
| 281 canvas_rect.Inset(0, 0, -1, -1); | 281 canvas_rect.Inset(0, 0, -1, -1); |
| 282 | 282 |
| 283 SkBitmap bitmap; | 283 SkBitmap bitmap; |
| 284 bitmap.allocN32Pixels(canvas_rect.width(), canvas_rect.height()); | 284 bitmap.allocN32Pixels(canvas_rect.width(), canvas_rect.height()); |
| 285 SkCanvas canvas(bitmap); | 285 SkCanvas canvas(bitmap); |
| 286 canvas.clear(SK_ColorTRANSPARENT); | 286 canvas.clear(SK_ColorTRANSPARENT); |
| 287 | 287 |
| 288 const bool include_images = true; | |
| 289 raster->PlaybackToCanvas(&canvas, canvas_rect, canvas_rect, | 288 raster->PlaybackToCanvas(&canvas, canvas_rect, canvas_rect, |
| 290 contents_scale, include_images); | 289 contents_scale, |
| 290 RasterSource::PlaybackSettings()); |
| 291 | 291 |
| 292 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); | 292 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); |
| 293 int num_pixels = bitmap.width() * bitmap.height(); | 293 int num_pixels = bitmap.width() * bitmap.height(); |
| 294 bool all_white = true; | 294 bool all_white = true; |
| 295 for (int i = 0; i < num_pixels; ++i) { | 295 for (int i = 0; i < num_pixels; ++i) { |
| 296 EXPECT_EQ(SkColorGetA(pixels[i]), 255u); | 296 EXPECT_EQ(SkColorGetA(pixels[i]), 255u); |
| 297 all_white &= (SkColorGetR(pixels[i]) == 255); | 297 all_white &= (SkColorGetR(pixels[i]) == 255); |
| 298 all_white &= (SkColorGetG(pixels[i]) == 255); | 298 all_white &= (SkColorGetG(pixels[i]) == 255); |
| 299 all_white &= (SkColorGetB(pixels[i]) == 255); | 299 all_white &= (SkColorGetB(pixels[i]) == 255); |
| 300 } | 300 } |
| (...skipping 29 matching lines...) Expand all Loading... |
| 330 gfx::ScaleToCeiledSize(layer_bounds, contents_scale)); | 330 gfx::ScaleToCeiledSize(layer_bounds, contents_scale)); |
| 331 | 331 |
| 332 SkBitmap bitmap; | 332 SkBitmap bitmap; |
| 333 bitmap.allocN32Pixels(content_bounds.width(), content_bounds.height()); | 333 bitmap.allocN32Pixels(content_bounds.width(), content_bounds.height()); |
| 334 SkCanvas canvas(bitmap); | 334 SkCanvas canvas(bitmap); |
| 335 canvas.clear(SK_ColorTRANSPARENT); | 335 canvas.clear(SK_ColorTRANSPARENT); |
| 336 | 336 |
| 337 // Playback the full rect which should make everything white. | 337 // Playback the full rect which should make everything white. |
| 338 gfx::Rect raster_full_rect(content_bounds); | 338 gfx::Rect raster_full_rect(content_bounds); |
| 339 gfx::Rect playback_rect(content_bounds); | 339 gfx::Rect playback_rect(content_bounds); |
| 340 const bool include_images = true; | |
| 341 raster->PlaybackToCanvas(&canvas, raster_full_rect, playback_rect, | 340 raster->PlaybackToCanvas(&canvas, raster_full_rect, playback_rect, |
| 342 contents_scale, include_images); | 341 contents_scale, RasterSource::PlaybackSettings()); |
| 343 | 342 |
| 344 { | 343 { |
| 345 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); | 344 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); |
| 346 for (int i = 0; i < bitmap.width(); ++i) { | 345 for (int i = 0; i < bitmap.width(); ++i) { |
| 347 for (int j = 0; j < bitmap.height(); ++j) { | 346 for (int j = 0; j < bitmap.height(); ++j) { |
| 348 SCOPED_TRACE(i); | 347 SCOPED_TRACE(i); |
| 349 SCOPED_TRACE(j); | 348 SCOPED_TRACE(j); |
| 350 EXPECT_EQ(255u, SkColorGetA(pixels[i + j * bitmap.width()])); | 349 EXPECT_EQ(255u, SkColorGetA(pixels[i + j * bitmap.width()])); |
| 351 EXPECT_EQ(255u, SkColorGetR(pixels[i + j * bitmap.width()])); | 350 EXPECT_EQ(255u, SkColorGetR(pixels[i + j * bitmap.width()])); |
| 352 EXPECT_EQ(255u, SkColorGetG(pixels[i + j * bitmap.width()])); | 351 EXPECT_EQ(255u, SkColorGetG(pixels[i + j * bitmap.width()])); |
| (...skipping 10 matching lines...) Expand all Loading... |
| 363 recording_source->Rerecord(); | 362 recording_source->Rerecord(); |
| 364 | 363 |
| 365 // Make a new RasterSource from the new recording. | 364 // Make a new RasterSource from the new recording. |
| 366 raster = | 365 raster = |
| 367 RasterSource::CreateFromRecordingSource(recording_source.get(), false); | 366 RasterSource::CreateFromRecordingSource(recording_source.get(), false); |
| 368 | 367 |
| 369 // We're going to playback from "everything is black" into a smaller area, | 368 // We're going to playback from "everything is black" into a smaller area, |
| 370 // that touches the edge pixels of the recording. | 369 // that touches the edge pixels of the recording. |
| 371 playback_rect.Inset(1, 2, 0, 1); | 370 playback_rect.Inset(1, 2, 0, 1); |
| 372 raster->PlaybackToCanvas(&canvas, raster_full_rect, playback_rect, | 371 raster->PlaybackToCanvas(&canvas, raster_full_rect, playback_rect, |
| 373 contents_scale, include_images); | 372 contents_scale, RasterSource::PlaybackSettings()); |
| 374 | 373 |
| 375 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); | 374 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); |
| 376 int num_black = 0; | 375 int num_black = 0; |
| 377 int num_white = 0; | 376 int num_white = 0; |
| 378 for (int i = 0; i < bitmap.width(); ++i) { | 377 for (int i = 0; i < bitmap.width(); ++i) { |
| 379 for (int j = 0; j < bitmap.height(); ++j) { | 378 for (int j = 0; j < bitmap.height(); ++j) { |
| 380 SCOPED_TRACE(j); | 379 SCOPED_TRACE(j); |
| 381 SCOPED_TRACE(i); | 380 SCOPED_TRACE(i); |
| 382 bool expect_black = playback_rect.Contains(i, j); | 381 bool expect_black = playback_rect.Contains(i, j); |
| 383 if (expect_black) { | 382 if (expect_black) { |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 426 gfx::ScaleToCeiledSize(layer_bounds, contents_scale)); | 425 gfx::ScaleToCeiledSize(layer_bounds, contents_scale)); |
| 427 | 426 |
| 428 SkBitmap bitmap; | 427 SkBitmap bitmap; |
| 429 bitmap.allocN32Pixels(content_bounds.width(), content_bounds.height()); | 428 bitmap.allocN32Pixels(content_bounds.width(), content_bounds.height()); |
| 430 SkCanvas canvas(bitmap); | 429 SkCanvas canvas(bitmap); |
| 431 canvas.clear(SK_ColorTRANSPARENT); | 430 canvas.clear(SK_ColorTRANSPARENT); |
| 432 | 431 |
| 433 // Playback the full rect which should make everything light gray (alpha=10). | 432 // Playback the full rect which should make everything light gray (alpha=10). |
| 434 gfx::Rect raster_full_rect(content_bounds); | 433 gfx::Rect raster_full_rect(content_bounds); |
| 435 gfx::Rect playback_rect(content_bounds); | 434 gfx::Rect playback_rect(content_bounds); |
| 436 const bool include_images = true; | |
| 437 raster->PlaybackToCanvas(&canvas, raster_full_rect, playback_rect, | 435 raster->PlaybackToCanvas(&canvas, raster_full_rect, playback_rect, |
| 438 contents_scale, include_images); | 436 contents_scale, RasterSource::PlaybackSettings()); |
| 439 | 437 |
| 440 { | 438 { |
| 441 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); | 439 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); |
| 442 for (int i = 0; i < bitmap.width(); ++i) { | 440 for (int i = 0; i < bitmap.width(); ++i) { |
| 443 for (int j = 0; j < bitmap.height(); ++j) { | 441 for (int j = 0; j < bitmap.height(); ++j) { |
| 444 SCOPED_TRACE(i); | 442 SCOPED_TRACE(i); |
| 445 SCOPED_TRACE(j); | 443 SCOPED_TRACE(j); |
| 446 EXPECT_EQ(alpha_dark, SkColorGetA(pixels[i + j * bitmap.width()])); | 444 EXPECT_EQ(alpha_dark, SkColorGetA(pixels[i + j * bitmap.width()])); |
| 447 EXPECT_EQ(alpha_dark, SkColorGetR(pixels[i + j * bitmap.width()])); | 445 EXPECT_EQ(alpha_dark, SkColorGetR(pixels[i + j * bitmap.width()])); |
| 448 EXPECT_EQ(alpha_dark, SkColorGetG(pixels[i + j * bitmap.width()])); | 446 EXPECT_EQ(alpha_dark, SkColorGetG(pixels[i + j * bitmap.width()])); |
| (...skipping 18 matching lines...) Expand all Loading... |
| 467 // Make a new RasterSource from the new recording. | 465 // Make a new RasterSource from the new recording. |
| 468 raster = RasterSource::CreateFromRecordingSource(recording_source_light.get(), | 466 raster = RasterSource::CreateFromRecordingSource(recording_source_light.get(), |
| 469 false); | 467 false); |
| 470 | 468 |
| 471 // We're going to playback from alpha(18) white rectangle into a smaller area | 469 // We're going to playback from alpha(18) white rectangle into a smaller area |
| 472 // of the recording resulting in a smaller lighter white rectangle over a | 470 // of the recording resulting in a smaller lighter white rectangle over a |
| 473 // darker white background rectangle. | 471 // darker white background rectangle. |
| 474 playback_rect = | 472 playback_rect = |
| 475 gfx::Rect(gfx::ScaleToCeiledSize(partial_bounds, contents_scale)); | 473 gfx::Rect(gfx::ScaleToCeiledSize(partial_bounds, contents_scale)); |
| 476 raster->PlaybackToCanvas(&canvas, raster_full_rect, playback_rect, | 474 raster->PlaybackToCanvas(&canvas, raster_full_rect, playback_rect, |
| 477 contents_scale, include_images); | 475 contents_scale, RasterSource::PlaybackSettings()); |
| 478 | 476 |
| 479 // Test that the whole playback_rect was cleared and repainted with new alpha. | 477 // Test that the whole playback_rect was cleared and repainted with new alpha. |
| 480 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); | 478 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); |
| 481 for (int i = 0; i < playback_rect.width(); ++i) { | 479 for (int i = 0; i < playback_rect.width(); ++i) { |
| 482 for (int j = 0; j < playback_rect.height(); ++j) { | 480 for (int j = 0; j < playback_rect.height(); ++j) { |
| 483 SCOPED_TRACE(j); | 481 SCOPED_TRACE(j); |
| 484 SCOPED_TRACE(i); | 482 SCOPED_TRACE(i); |
| 485 EXPECT_EQ(alpha_light, SkColorGetA(pixels[i + j * bitmap.width()])); | 483 EXPECT_EQ(alpha_light, SkColorGetA(pixels[i + j * bitmap.width()])); |
| 486 EXPECT_EQ(alpha_light, SkColorGetR(pixels[i + j * bitmap.width()])); | 484 EXPECT_EQ(alpha_light, SkColorGetR(pixels[i + j * bitmap.width()])); |
| 487 EXPECT_EQ(alpha_light, SkColorGetG(pixels[i + j * bitmap.width()])); | 485 EXPECT_EQ(alpha_light, SkColorGetG(pixels[i + j * bitmap.width()])); |
| (...skipping 18 matching lines...) Expand all Loading... |
| 506 gfx::Size content_bounds( | 504 gfx::Size content_bounds( |
| 507 gfx::ScaleToCeiledSize(layer_bounds, contents_scale)); | 505 gfx::ScaleToCeiledSize(layer_bounds, contents_scale)); |
| 508 | 506 |
| 509 gfx::Rect canvas_rect(content_bounds); | 507 gfx::Rect canvas_rect(content_bounds); |
| 510 canvas_rect.Inset(0, 0, -1, -1); | 508 canvas_rect.Inset(0, 0, -1, -1); |
| 511 | 509 |
| 512 SkBitmap bitmap; | 510 SkBitmap bitmap; |
| 513 bitmap.allocN32Pixels(canvas_rect.width(), canvas_rect.height()); | 511 bitmap.allocN32Pixels(canvas_rect.width(), canvas_rect.height()); |
| 514 SkCanvas canvas(bitmap); | 512 SkCanvas canvas(bitmap); |
| 515 | 513 |
| 516 const bool include_images = true; | |
| 517 raster->PlaybackToCanvas(&canvas, canvas_rect, canvas_rect, contents_scale, | 514 raster->PlaybackToCanvas(&canvas, canvas_rect, canvas_rect, contents_scale, |
| 518 include_images); | 515 RasterSource::PlaybackSettings()); |
| 519 | 516 |
| 520 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); | 517 SkColor* pixels = reinterpret_cast<SkColor*>(bitmap.getPixels()); |
| 521 int num_pixels = bitmap.width() * bitmap.height(); | 518 int num_pixels = bitmap.width() * bitmap.height(); |
| 522 for (int i = 0; i < num_pixels; ++i) { | 519 for (int i = 0; i < num_pixels; ++i) { |
| 523 EXPECT_EQ(SkColorGetA(pixels[i]), 0u); | 520 EXPECT_EQ(SkColorGetA(pixels[i]), 0u); |
| 524 } | 521 } |
| 525 } | 522 } |
| 526 | 523 |
| 527 TEST(RasterSourceTest, GetPictureMemoryUsageIncludesClientReportedMemory) { | 524 TEST(RasterSourceTest, GetPictureMemoryUsageIncludesClientReportedMemory) { |
| 528 const size_t kReportedMemoryUsageInBytes = 100 * 1024 * 1024; | 525 const size_t kReportedMemoryUsageInBytes = 100 * 1024 * 1024; |
| 529 gfx::Size layer_bounds(5, 3); | 526 gfx::Size layer_bounds(5, 3); |
| 530 scoped_ptr<FakeRecordingSource> recording_source = | 527 scoped_ptr<FakeRecordingSource> recording_source = |
| 531 FakeRecordingSource::CreateFilledRecordingSource(layer_bounds); | 528 FakeRecordingSource::CreateFilledRecordingSource(layer_bounds); |
| 532 recording_source->set_reported_memory_usage(kReportedMemoryUsageInBytes); | 529 recording_source->set_reported_memory_usage(kReportedMemoryUsageInBytes); |
| 533 recording_source->Rerecord(); | 530 recording_source->Rerecord(); |
| 534 | 531 |
| 535 scoped_refptr<RasterSource> raster = | 532 scoped_refptr<RasterSource> raster = |
| 536 RasterSource::CreateFromRecordingSource(recording_source.get(), false); | 533 RasterSource::CreateFromRecordingSource(recording_source.get(), false); |
| 537 size_t total_memory_usage = raster->GetPictureMemoryUsage(); | 534 size_t total_memory_usage = raster->GetPictureMemoryUsage(); |
| 538 EXPECT_GE(total_memory_usage, kReportedMemoryUsageInBytes); | 535 EXPECT_GE(total_memory_usage, kReportedMemoryUsageInBytes); |
| 539 EXPECT_LT(total_memory_usage, 2 * kReportedMemoryUsageInBytes); | 536 EXPECT_LT(total_memory_usage, 2 * kReportedMemoryUsageInBytes); |
| 540 } | 537 } |
| 541 | 538 |
| 542 } // namespace | 539 } // namespace |
| 543 } // namespace cc | 540 } // namespace cc |
| OLD | NEW |