Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/base/scoped_ptr_vector.h" | 5 #include "cc/base/scoped_ptr_vector.h" |
| 6 #include "cc/output/compositor_frame_metadata.h" | 6 #include "cc/output/compositor_frame_metadata.h" |
| 7 #include "cc/output/gl_renderer.h" | 7 #include "cc/output/gl_renderer.h" |
| 8 #include "cc/output/output_surface.h" | 8 #include "cc/output/output_surface.h" |
| 9 #include "cc/output/output_surface_client.h" | 9 #include "cc/output/output_surface_client.h" |
| 10 #include "cc/output/overlay_candidate_validator.h" | 10 #include "cc/output/overlay_candidate_validator.h" |
| 11 #include "cc/output/overlay_processor.h" | 11 #include "cc/output/overlay_processor.h" |
| 12 #include "cc/output/overlay_strategy_single_on_top.h" | 12 #include "cc/output/overlay_strategy_single_on_top.h" |
| 13 #include "cc/output/overlay_strategy_underlay.h" | 13 #include "cc/output/overlay_strategy_underlay.h" |
| 14 #include "cc/quads/checkerboard_draw_quad.h" | 14 #include "cc/quads/checkerboard_draw_quad.h" |
| 15 #include "cc/quads/render_pass.h" | 15 #include "cc/quads/render_pass.h" |
| 16 #include "cc/quads/stream_video_draw_quad.h" | 16 #include "cc/quads/stream_video_draw_quad.h" |
| 17 #include "cc/quads/texture_draw_quad.h" | 17 #include "cc/quads/texture_draw_quad.h" |
| 18 #include "cc/resources/resource_provider.h" | 18 #include "cc/resources/resource_provider.h" |
| 19 #include "cc/resources/texture_mailbox.h" | 19 #include "cc/resources/texture_mailbox.h" |
| 20 #include "cc/test/fake_output_surface_client.h" | 20 #include "cc/test/fake_output_surface_client.h" |
| 21 #include "cc/test/geometry_test_utils.h" | 21 #include "cc/test/geometry_test_utils.h" |
| 22 #include "cc/test/test_context_provider.h" | 22 #include "cc/test/test_context_provider.h" |
| 23 #include "cc/test/test_shared_bitmap_manager.h" | 23 #include "cc/test/test_shared_bitmap_manager.h" |
| 24 #include "testing/gmock/include/gmock/gmock.h" | 24 #include "testing/gmock/include/gmock/gmock.h" |
| 25 #include "testing/gtest/include/gtest/gtest.h" | 25 #include "testing/gtest/include/gtest/gtest.h" |
| 26 #include "ui/gfx/geometry/rect_conversions.h" | |
| 26 | 27 |
| 27 using testing::_; | 28 using testing::_; |
| 28 using testing::Mock; | 29 using testing::Mock; |
| 29 | 30 |
| 30 namespace cc { | 31 namespace cc { |
| 31 namespace { | 32 namespace { |
| 32 | 33 |
| 33 const gfx::Rect kOverlayRect(0, 0, 128, 128); | 34 const gfx::Rect kOverlayRect(0, 0, 128, 128); |
| 34 const gfx::Rect kOverlayTopLeftRect(0, 0, 64, 64); | 35 const gfx::Rect kOverlayTopLeftRect(0, 0, 64, 64); |
| 35 const gfx::Rect kOverlayBottomRightRect(64, 64, 64, 64); | 36 const gfx::Rect kOverlayBottomRightRect(64, 64, 64, 64); |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 54 class SingleOverlayValidator : public OverlayCandidateValidator { | 55 class SingleOverlayValidator : public OverlayCandidateValidator { |
| 55 public: | 56 public: |
| 56 void CheckOverlaySupport(OverlayCandidateList* surfaces) override; | 57 void CheckOverlaySupport(OverlayCandidateList* surfaces) override; |
| 57 }; | 58 }; |
| 58 | 59 |
| 59 void SingleOverlayValidator::CheckOverlaySupport( | 60 void SingleOverlayValidator::CheckOverlaySupport( |
| 60 OverlayCandidateList* surfaces) { | 61 OverlayCandidateList* surfaces) { |
| 61 ASSERT_EQ(2U, surfaces->size()); | 62 ASSERT_EQ(2U, surfaces->size()); |
| 62 | 63 |
| 63 OverlayCandidate& candidate = surfaces->back(); | 64 OverlayCandidate& candidate = surfaces->back(); |
| 65 | |
| 66 // Reject non-integer rectangles | |
| 67 if (!gfx::IsNearestRectWithinDistance(candidate.display_rect, 0.01f)) | |
|
achaulk
2015/04/29 21:37:03
I'm not really sure this is useful - the test code
halliwell
2015/04/29 21:42:55
Agreed, will delete this test now.
| |
| 68 return; | |
| 69 | |
| 64 if (candidate.display_rect.width() == 64) | 70 if (candidate.display_rect.width() == 64) |
| 65 EXPECT_EQ(kOverlayBottomRightRect, candidate.display_rect); | 71 EXPECT_EQ(kOverlayBottomRightRect, candidate.display_rect); |
| 66 else | 72 else |
| 67 EXPECT_EQ(kOverlayRect, candidate.display_rect); | 73 EXPECT_EQ(kOverlayRect, candidate.display_rect); |
| 68 EXPECT_EQ(BoundingRect(kUVTopLeft, kUVBottomRight).ToString(), | 74 EXPECT_EQ(BoundingRect(kUVTopLeft, kUVBottomRight).ToString(), |
| 69 candidate.uv_rect.ToString()); | 75 candidate.uv_rect.ToString()); |
| 70 candidate.overlay_handled = true; | 76 candidate.overlay_handled = true; |
| 71 } | 77 } |
| 72 | 78 |
| 73 template <typename OverlayStrategyType> | 79 template <typename OverlayStrategyType> |
| (...skipping 508 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 582 1.0f); | 588 1.0f); |
| 583 | 589 |
| 584 RenderPassList pass_list; | 590 RenderPassList pass_list; |
| 585 pass_list.push_back(pass.Pass()); | 591 pass_list.push_back(pass.Pass()); |
| 586 OverlayCandidateList candidate_list; | 592 OverlayCandidateList candidate_list; |
| 587 overlay_processor_->ProcessForOverlays(&pass_list, &candidate_list); | 593 overlay_processor_->ProcessForOverlays(&pass_list, &candidate_list); |
| 588 ASSERT_EQ(1U, pass_list.size()); | 594 ASSERT_EQ(1U, pass_list.size()); |
| 589 EXPECT_EQ(2U, candidate_list.size()); | 595 EXPECT_EQ(2U, candidate_list.size()); |
| 590 } | 596 } |
| 591 | 597 |
| 598 TEST_F(SingleOverlayOnTopTest, CanRejectNonIntegerTranslation) { | |
| 599 gfx::Rect rect = kOverlayRect; | |
| 600 rect.Offset(-1, -1); | |
| 601 rect.Inset(0, 0, -1, -1); | |
| 602 scoped_ptr<RenderPass> pass = CreateRenderPass(); | |
| 603 CreateCandidateQuadAt(resource_provider_.get(), | |
| 604 pass->shared_quad_state_list.back(), pass.get(), rect); | |
| 605 pass->shared_quad_state_list.back()->content_to_target_transform.Translate( | |
| 606 0.5f, 0.5f); | |
| 607 | |
| 608 RenderPassList pass_list; | |
| 609 pass_list.push_back(pass.Pass()); | |
| 610 OverlayCandidateList candidate_list; | |
| 611 overlay_processor_->ProcessForOverlays(&pass_list, &candidate_list); | |
| 612 ASSERT_EQ(1U, pass_list.size()); | |
| 613 EXPECT_EQ(0U, candidate_list.size()); | |
| 614 } | |
| 615 | |
| 592 TEST_F(SingleOverlayOnTopTest, AllowNotTopIfNotOccluded) { | 616 TEST_F(SingleOverlayOnTopTest, AllowNotTopIfNotOccluded) { |
| 593 scoped_ptr<RenderPass> pass = CreateRenderPass(); | 617 scoped_ptr<RenderPass> pass = CreateRenderPass(); |
| 594 CreateCheckeredQuadAt(resource_provider_.get(), | 618 CreateCheckeredQuadAt(resource_provider_.get(), |
| 595 pass->shared_quad_state_list.back(), | 619 pass->shared_quad_state_list.back(), |
| 596 pass.get(), | 620 pass.get(), |
| 597 kOverlayTopLeftRect); | 621 kOverlayTopLeftRect); |
| 598 CreateCandidateQuadAt(resource_provider_.get(), | 622 CreateCandidateQuadAt(resource_provider_.get(), |
| 599 pass->shared_quad_state_list.back(), | 623 pass->shared_quad_state_list.back(), |
| 600 pass.get(), | 624 pass.get(), |
| 601 kOverlayBottomRightRect); | 625 kOverlayBottomRightRect); |
| (...skipping 501 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1103 renderer_->BeginDrawingFrame(&frame3); | 1127 renderer_->BeginDrawingFrame(&frame3); |
| 1104 renderer_->FinishDrawingFrame(&frame3); | 1128 renderer_->FinishDrawingFrame(&frame3); |
| 1105 EXPECT_TRUE(resource_provider_->InUseByConsumer(resource1)); | 1129 EXPECT_TRUE(resource_provider_->InUseByConsumer(resource1)); |
| 1106 SwapBuffers(); | 1130 SwapBuffers(); |
| 1107 EXPECT_FALSE(resource_provider_->InUseByConsumer(resource1)); | 1131 EXPECT_FALSE(resource_provider_->InUseByConsumer(resource1)); |
| 1108 Mock::VerifyAndClearExpectations(&scheduler_); | 1132 Mock::VerifyAndClearExpectations(&scheduler_); |
| 1109 } | 1133 } |
| 1110 | 1134 |
| 1111 } // namespace | 1135 } // namespace |
| 1112 } // namespace cc | 1136 } // namespace cc |
| OLD | NEW |