| 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/layers/surface_layer_impl.h" | 5 #include "cc/layers/surface_layer_impl.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include "cc/layers/append_quads_data.h" | 9 #include "cc/layers/append_quads_data.h" |
| 10 #include "cc/test/layer_test_common.h" | 10 #include "cc/test/layer_test_common.h" |
| 11 #include "testing/gtest/include/gtest/gtest.h" | 11 #include "testing/gtest/include/gtest/gtest.h" |
| 12 | 12 |
| 13 namespace cc { | 13 namespace cc { |
| 14 namespace { | 14 namespace { |
| 15 | 15 |
| 16 static constexpr FrameSinkId kArbitraryFrameSinkId(1, 1); | 16 static constexpr FrameSinkId kArbitraryFrameSinkId(1, 1); |
| 17 | 17 |
| 18 TEST(SurfaceLayerImplTest, Occlusion) { | 18 TEST(SurfaceLayerImplTest, Occlusion) { |
| 19 gfx::Size layer_size(1000, 1000); | 19 gfx::Size layer_size(1000, 1000); |
| 20 gfx::Size viewport_size(1000, 1000); | 20 gfx::Size viewport_size(1000, 1000); |
| 21 const LocalFrameId kArbitraryLocalFrameId(9, | 21 const LocalSurfaceId kArbitraryLocalSurfaceId( |
| 22 base::UnguessableToken::Create()); | 22 9, base::UnguessableToken::Create()); |
| 23 | 23 |
| 24 LayerTestCommon::LayerImplTest impl; | 24 LayerTestCommon::LayerImplTest impl; |
| 25 | 25 |
| 26 SurfaceLayerImpl* surface_layer_impl = | 26 SurfaceLayerImpl* surface_layer_impl = |
| 27 impl.AddChildToRoot<SurfaceLayerImpl>(); | 27 impl.AddChildToRoot<SurfaceLayerImpl>(); |
| 28 surface_layer_impl->SetBounds(layer_size); | 28 surface_layer_impl->SetBounds(layer_size); |
| 29 surface_layer_impl->SetDrawsContent(true); | 29 surface_layer_impl->SetDrawsContent(true); |
| 30 SurfaceId surface_id(kArbitraryFrameSinkId, kArbitraryLocalFrameId); | 30 SurfaceId surface_id(kArbitraryFrameSinkId, kArbitraryLocalSurfaceId); |
| 31 surface_layer_impl->SetSurfaceInfo(SurfaceInfo(surface_id, 1.f, layer_size)); | 31 surface_layer_impl->SetSurfaceInfo(SurfaceInfo(surface_id, 1.f, layer_size)); |
| 32 | 32 |
| 33 impl.CalcDrawProps(viewport_size); | 33 impl.CalcDrawProps(viewport_size); |
| 34 | 34 |
| 35 { | 35 { |
| 36 SCOPED_TRACE("No occlusion"); | 36 SCOPED_TRACE("No occlusion"); |
| 37 gfx::Rect occluded; | 37 gfx::Rect occluded; |
| 38 impl.AppendQuadsWithOcclusion(surface_layer_impl, occluded); | 38 impl.AppendQuadsWithOcclusion(surface_layer_impl, occluded); |
| 39 | 39 |
| 40 LayerTestCommon::VerifyQuadsExactlyCoverRect(impl.quad_list(), | 40 LayerTestCommon::VerifyQuadsExactlyCoverRect(impl.quad_list(), |
| (...skipping 21 matching lines...) Expand all Loading... |
| 62 // The layer outputs one quad, which is partially occluded. | 62 // The layer outputs one quad, which is partially occluded. |
| 63 EXPECT_EQ(1u, impl.quad_list().size()); | 63 EXPECT_EQ(1u, impl.quad_list().size()); |
| 64 EXPECT_EQ(1u, partially_occluded_count); | 64 EXPECT_EQ(1u, partially_occluded_count); |
| 65 } | 65 } |
| 66 } | 66 } |
| 67 | 67 |
| 68 TEST(SurfaceLayerImplTest, SurfaceStretchedToLayerBounds) { | 68 TEST(SurfaceLayerImplTest, SurfaceStretchedToLayerBounds) { |
| 69 LayerTestCommon::LayerImplTest impl; | 69 LayerTestCommon::LayerImplTest impl; |
| 70 SurfaceLayerImpl* surface_layer_impl = | 70 SurfaceLayerImpl* surface_layer_impl = |
| 71 impl.AddChildToRoot<SurfaceLayerImpl>(); | 71 impl.AddChildToRoot<SurfaceLayerImpl>(); |
| 72 const LocalFrameId kArbitraryLocalFrameId(9, | 72 const LocalSurfaceId kArbitraryLocalSurfaceId( |
| 73 base::UnguessableToken::Create()); | 73 9, base::UnguessableToken::Create()); |
| 74 | 74 |
| 75 // Given condition: layer and surface have different size and different | 75 // Given condition: layer and surface have different size and different |
| 76 // aspect ratios. | 76 // aspect ratios. |
| 77 gfx::Size layer_size(400, 100); | 77 gfx::Size layer_size(400, 100); |
| 78 gfx::Size surface_size(300, 300); | 78 gfx::Size surface_size(300, 300); |
| 79 gfx::Size viewport_size(1000, 1000); | 79 gfx::Size viewport_size(1000, 1000); |
| 80 float surface_scale = 1.f; | 80 float surface_scale = 1.f; |
| 81 gfx::Transform target_space_transform( | 81 gfx::Transform target_space_transform( |
| 82 surface_layer_impl->draw_properties().target_space_transform); | 82 surface_layer_impl->draw_properties().target_space_transform); |
| 83 | 83 |
| 84 // The following code is mimicking the PushPropertiesTo from pending to | 84 // The following code is mimicking the PushPropertiesTo from pending to |
| 85 // active tree. | 85 // active tree. |
| 86 surface_layer_impl->SetBounds(layer_size); | 86 surface_layer_impl->SetBounds(layer_size); |
| 87 surface_layer_impl->SetDrawsContent(true); | 87 surface_layer_impl->SetDrawsContent(true); |
| 88 SurfaceId surface_id(kArbitraryFrameSinkId, kArbitraryLocalFrameId); | 88 SurfaceId surface_id(kArbitraryFrameSinkId, kArbitraryLocalSurfaceId); |
| 89 surface_layer_impl->SetSurfaceInfo( | 89 surface_layer_impl->SetSurfaceInfo( |
| 90 SurfaceInfo(surface_id, surface_scale, surface_size)); | 90 SurfaceInfo(surface_id, surface_scale, surface_size)); |
| 91 surface_layer_impl->SetStretchContentToFillBounds(true); | 91 surface_layer_impl->SetStretchContentToFillBounds(true); |
| 92 | 92 |
| 93 impl.CalcDrawProps(viewport_size); | 93 impl.CalcDrawProps(viewport_size); |
| 94 | 94 |
| 95 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | 95 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); |
| 96 AppendQuadsData data; | 96 AppendQuadsData data; |
| 97 surface_layer_impl->AppendQuads(render_pass.get(), &data); | 97 surface_layer_impl->AppendQuads(render_pass.get(), &data); |
| 98 | 98 |
| (...skipping 21 matching lines...) Expand all Loading... |
| 120 gfx::RectF layer_rect(layer_size.width(), layer_size.height()); | 120 gfx::RectF layer_rect(layer_size.width(), layer_size.height()); |
| 121 gfx::RectF transformed_layer_rect = | 121 gfx::RectF transformed_layer_rect = |
| 122 MathUtil::MapClippedRect(target_space_transform, layer_rect); | 122 MathUtil::MapClippedRect(target_space_transform, layer_rect); |
| 123 | 123 |
| 124 // Check if quad rect in target space matches layer rect in target space | 124 // Check if quad rect in target space matches layer rect in target space |
| 125 EXPECT_EQ(transformed_quad_rect, transformed_layer_rect); | 125 EXPECT_EQ(transformed_quad_rect, transformed_layer_rect); |
| 126 } | 126 } |
| 127 | 127 |
| 128 } // namespace | 128 } // namespace |
| 129 } // namespace cc | 129 } // namespace cc |
| OLD | NEW |