| Index: cc/layers/delegated_renderer_layer_impl_unittest.cc
|
| diff --git a/cc/layers/delegated_renderer_layer_impl_unittest.cc b/cc/layers/delegated_renderer_layer_impl_unittest.cc
|
| index 3f30d15a3b79651463f9e31df14ad4a86b8e3002..fbaf8bbf24f5bb44292e10dd046f72fdbf1000b4 100644
|
| --- a/cc/layers/delegated_renderer_layer_impl_unittest.cc
|
| +++ b/cc/layers/delegated_renderer_layer_impl_unittest.cc
|
| @@ -109,7 +109,7 @@ class DelegatedRendererLayerImplTestSimple
|
| gfx::Transform(1, 0, 0, 1, 9, 10));
|
| AddRenderPassQuad(pass3, pass2);
|
| delegated_renderer_layer->SetFrameDataForRenderPasses(
|
| - &delegated_render_passes);
|
| + 1.f, &delegated_render_passes);
|
|
|
| // The RenderPasses should be taken by the layer.
|
| EXPECT_EQ(0u, delegated_render_passes.size());
|
| @@ -245,11 +245,8 @@ TEST_F(DelegatedRendererLayerImplTestSimple,
|
| // The DelegatedRendererLayer is at position 3,3 compared to its target, and
|
| // has a translation transform of 1,1. So its root RenderPass' quads should
|
| // all be transformed by that combined amount.
|
| - // The DelegatedRendererLayer has a size of 10x10, but the root delegated
|
| - // RenderPass has a size of 8x8, so any quads should be scaled by 10/8.
|
| gfx::Transform transform;
|
| transform.Translate(4.0, 4.0);
|
| - transform.Scale(10.0 / 8.0, 10.0 / 8.0);
|
| EXPECT_TRANSFORMATION_MATRIX_EQ(
|
| transform, frame.render_passes[3]->quad_list[0]->quadTransform());
|
|
|
| @@ -280,12 +277,8 @@ TEST_F(DelegatedRendererLayerImplTestSimple, RenderPassTransformIsModified) {
|
|
|
| // The DelegatedRendererLayer is at position 9,9 compared to the root, so all
|
| // render pass' transforms to the root should be shifted by this amount.
|
| - // The DelegatedRendererLayer has a size of 10x10, but the root delegated
|
| - // RenderPass has a size of 8x8, so any render passes should be scaled by
|
| - // 10/8.
|
| gfx::Transform transform;
|
| transform.Translate(9.0, 9.0);
|
| - transform.Scale(10.0 / 8.0, 10.0 / 8.0);
|
|
|
| // The first contributing surface has a translation of 5, 6.
|
| gfx::Transform five_six(1, 0, 0, 1, 5, 6);
|
| @@ -468,12 +461,9 @@ TEST_F(DelegatedRendererLayerImplTestOwnSurface,
|
| ASSERT_EQ(6u, frame.render_passes.size());
|
|
|
| // Because the DelegatedRendererLayer owns a RenderSurfaceImpl, its root
|
| - // RenderPass' quads do not need to be translated at all. However, they are
|
| - // scaled from the frame's size (8x8) to the layer's bounds (10x10).
|
| - gfx::Transform transform;
|
| - transform.Scale(10.0 / 8.0, 10.0 / 8.0);
|
| + // RenderPass' quads do not need to be translated at all.
|
| EXPECT_TRANSFORMATION_MATRIX_EQ(
|
| - transform, frame.render_passes[3]->quad_list[0]->quadTransform());
|
| + gfx::Transform(), frame.render_passes[3]->quad_list[0]->quadTransform());
|
|
|
| // Quads from non-root RenderPasses should not be shifted either.
|
| ASSERT_EQ(2u, frame.render_passes[2]->quad_list.size());
|
| @@ -492,6 +482,10 @@ TEST_F(DelegatedRendererLayerImplTestOwnSurface,
|
| class DelegatedRendererLayerImplTestTransform
|
| : public DelegatedRendererLayerImplTest {
|
| public:
|
| + DelegatedRendererLayerImplTestTransform()
|
| + : root_delegated_render_pass_is_clipped_(false),
|
| + delegated_device_scale_factor_(2.f) {}
|
| +
|
| void SetUpTest() {
|
| host_impl_->SetDeviceScaleFactor(2.f);
|
|
|
| @@ -511,8 +505,6 @@ class DelegatedRendererLayerImplTestTransform
|
| transform.Scale(2.0, 2.0);
|
| transform.Translate(8.0, 8.0);
|
| delegated_renderer_layer->SetTransform(transform);
|
| - delegated_renderer_layer->SetTransformOrigin(
|
| - gfx::Point3F(75 * 0.5f, 75 * 0.5f, 0.0f));
|
|
|
| ScopedPtrVector<RenderPass> delegated_render_passes;
|
|
|
| @@ -629,7 +621,7 @@ class DelegatedRendererLayerImplTestTransform
|
| pass->AppendDrawQuad(color_quad.PassAs<DrawQuad>());
|
|
|
| delegated_renderer_layer->SetFrameDataForRenderPasses(
|
| - &delegated_render_passes);
|
| + delegated_device_scale_factor_, &delegated_render_passes);
|
|
|
| // The RenderPasses should be taken by the layer.
|
| EXPECT_EQ(0u, delegated_render_passes.size());
|
| @@ -687,6 +679,7 @@ class DelegatedRendererLayerImplTestTransform
|
| LayerImpl* root_layer_;
|
| DelegatedRendererLayerImpl* delegated_renderer_layer_;
|
| bool root_delegated_render_pass_is_clipped_;
|
| + float delegated_device_scale_factor_;
|
| };
|
|
|
| TEST_F(DelegatedRendererLayerImplTestTransform, QuadsUnclipped_NoSurface) {
|
| @@ -715,16 +708,15 @@ TEST_F(DelegatedRendererLayerImplTestTransform, QuadsUnclipped_NoSurface) {
|
| EXPECT_TRUE(root_delegated_shared_quad_state->is_clipped);
|
|
|
| gfx::Transform expected;
|
| - // Device scale factor is 2.
|
| + // Device scale factor.
|
| expected.Scale(2.0, 2.0);
|
| // This is the transform from the layer's space to its target.
|
| - // The position (20) - the width / scale (75 / 2) = 20 - 37.5 = -17.5
|
| - expected.Translate(-17.5, -17.5);
|
| + expected.Translate(20, 20);
|
| expected.Scale(2.0, 2.0);
|
| expected.Translate(8.0, 8.0);
|
| - // The frame has size 100x100 but the layer's bounds are 75x75.
|
| - expected.Scale(75.0 / 100.0, 75.0 / 100.0);
|
| // This is the transform within the source frame.
|
| + // Inverse device scale factor to go from physical space to layer space.
|
| + expected.Scale(0.5, 0.5);
|
| expected.Scale(1.5, 1.5);
|
| expected.Translate(7.0, 7.0);
|
| EXPECT_TRANSFORMATION_MATRIX_EQ(
|
| @@ -763,31 +755,27 @@ TEST_F(DelegatedRendererLayerImplTestTransform, QuadsClipped_NoSurface) {
|
| // Since the quads have a clip_rect it should be modified by delegated
|
| // renderer layer's draw_transform.
|
| // The position of the resulting clip_rect is:
|
| - // (clip rect position (10) * scale to layer (75/100) + translate (8)) *
|
| - // layer scale (2) + layer position (20) = 51
|
| - // But the layer is centered, so: 51 - (75 / 2) = 51 - 75 / 2 = 13.5
|
| - // The device scale is 2, so everything gets doubled, giving 27.
|
| + // (clip rect position (10) * inverse dsf (1/2) + translate (8)) *
|
| + // layer scale (2) + layer position (20) = 46
|
| + // The device scale is 2, so everything gets doubled, giving 92.
|
| //
|
| - // The size is 35x35 scaled to fit inside the layer's bounds at 75x75 from
|
| - // a frame at 100x100: 35 * 2 (device scale) * 75 / 100 = 52.5. The device
|
| - // scale doubles this to 105.
|
| - EXPECT_EQ(gfx::Rect(27, 27, 105, 105).ToString(),
|
| + // The size is 35x35 scaled by the device scale.
|
| + EXPECT_EQ(gfx::Rect(92, 92, 70, 70).ToString(),
|
| root_delegated_shared_quad_state->clip_rect.ToString());
|
|
|
| // The quads had a clip and it should be preserved.
|
| EXPECT_TRUE(root_delegated_shared_quad_state->is_clipped);
|
|
|
| gfx::Transform expected;
|
| - // Device scale factor is 2.
|
| + // Device scale factor.
|
| expected.Scale(2.0, 2.0);
|
| // This is the transform from the layer's space to its target.
|
| - // The position (20) - the width / scale (75 / 2) = 20 - 37.5 = -17.5
|
| - expected.Translate(-17.5, -17.5);
|
| + expected.Translate(20, 20);
|
| expected.Scale(2.0, 2.0);
|
| expected.Translate(8.0, 8.0);
|
| - // The frame has size 100x100 but the layer's bounds are 75x75.
|
| - expected.Scale(75.0 / 100.0, 75.0 / 100.0);
|
| // This is the transform within the source frame.
|
| + // Inverse device scale factor to go from physical space to layer space.
|
| + expected.Scale(0.5, 0.5);
|
| expected.Scale(1.5, 1.5);
|
| expected.Translate(7.0, 7.0);
|
| EXPECT_TRANSFORMATION_MATRIX_EQ(
|
| @@ -827,11 +815,7 @@ TEST_F(DelegatedRendererLayerImplTestTransform, QuadsUnclipped_Surface) {
|
|
|
| // When the layer owns a surface, then its position and translation are not
|
| // a part of its draw transform.
|
| - // The position of the resulting clip_rect is:
|
| - // (clip rect position (10) * scale to layer (75/100)) * device scale (2) = 15
|
| - // The size is 35x35 scaled to fit inside the layer's bounds at 75x75 from
|
| - // a frame at 100x100: 35 * 2 (device scale) * 75 / 100 = 52.5.
|
| - EXPECT_EQ(gfx::Rect(15, 15, 53, 53).ToString(),
|
| + EXPECT_EQ(gfx::Rect(10, 10, 35, 35).ToString(),
|
| root_delegated_shared_quad_state->clip_rect.ToString());
|
|
|
| // Since the layer owns a surface it doesn't need to clip its quads, so
|
| @@ -839,10 +823,6 @@ TEST_F(DelegatedRendererLayerImplTestTransform, QuadsUnclipped_Surface) {
|
| EXPECT_FALSE(root_delegated_shared_quad_state->is_clipped);
|
|
|
| gfx::Transform expected;
|
| - // Device scale factor is 2.
|
| - expected.Scale(2.0, 2.0);
|
| - // The frame has size 100x100 but the layer's bounds are 75x75.
|
| - expected.Scale(75.0 / 100.0, 75.0 / 100.0);
|
| // This is the transform within the source frame.
|
| expected.Scale(1.5, 1.5);
|
| expected.Translate(7.0, 7.0);
|
| @@ -882,22 +862,14 @@ TEST_F(DelegatedRendererLayerImplTestTransform, QuadsClipped_Surface) {
|
| &contrib_delegated_shared_quad_state);
|
|
|
| // When the layer owns a surface, then its position and translation are not
|
| - // a part of its draw transform.
|
| - // The position of the resulting clip_rect is:
|
| - // (clip rect position (10) * scale to layer (75/100)) * device scale (2) = 15
|
| - // The size is 35x35 scaled to fit inside the layer's bounds at 75x75 from
|
| - // a frame at 100x100: 35 * 2 (device scale) * 75 / 100 = 52.5.
|
| - EXPECT_EQ(gfx::Rect(15, 15, 53, 53).ToString(),
|
| + // a part of its draw transform. The clip_rect should be preserved.
|
| + EXPECT_EQ(gfx::Rect(10, 10, 35, 35).ToString(),
|
| root_delegated_shared_quad_state->clip_rect.ToString());
|
|
|
| // The quads had a clip and it should be preserved.
|
| EXPECT_TRUE(root_delegated_shared_quad_state->is_clipped);
|
|
|
| gfx::Transform expected;
|
| - // Device scale factor is 2.
|
| - expected.Scale(2.0, 2.0);
|
| - // The frame has size 100x100 but the layer's bounds are 75x75.
|
| - expected.Scale(75.0 / 100.0, 75.0 / 100.0);
|
| // This is the transform within the source frame.
|
| expected.Scale(1.5, 1.5);
|
| expected.Translate(7.0, 7.0);
|
| @@ -919,6 +891,45 @@ TEST_F(DelegatedRendererLayerImplTestTransform, QuadsClipped_Surface) {
|
| host_impl_->DidDrawAllLayers(frame);
|
| }
|
|
|
| +TEST_F(DelegatedRendererLayerImplTestTransform, MismatchedDeviceScaleFactor) {
|
| + root_delegated_render_pass_is_clipped_ = true;
|
| + delegated_device_scale_factor_ = 1.3f;
|
| +
|
| + SetUpTest();
|
| +
|
| + LayerTreeHostImpl::FrameData frame;
|
| + EXPECT_EQ(DRAW_SUCCESS, host_impl_->PrepareToDraw(&frame));
|
| +
|
| + const SharedQuadState* root_delegated_shared_quad_state = NULL;
|
| + const SharedQuadState* contrib_delegated_shared_quad_state = NULL;
|
| + VerifyRenderPasses(frame,
|
| + 2,
|
| + &root_delegated_shared_quad_state,
|
| + &contrib_delegated_shared_quad_state);
|
| +
|
| + // The parent tree's device scale factor is 2.0, but the child has submitted a
|
| + // frame with a device scale factor of 1.3. Absent any better option, the
|
| + // only thing we can do is scale from 1.3 -> 2.0.
|
| +
|
| + gfx::Transform expected;
|
| + // Device scale factor (from parent).
|
| + expected.Scale(2.0, 2.0);
|
| + // This is the transform from the layer's space to its target.
|
| + expected.Translate(20, 20);
|
| + expected.Scale(2.0, 2.0);
|
| + expected.Translate(8.0, 8.0);
|
| + // This is the transform within the source frame.
|
| + // Inverse device scale factor (from child).
|
| + expected.Scale(1.0f / 1.3f, 1.0f / 1.3f);
|
| + expected.Scale(1.5, 1.5);
|
| + expected.Translate(7.0, 7.0);
|
| + EXPECT_TRANSFORMATION_MATRIX_EQ(
|
| + expected, root_delegated_shared_quad_state->content_to_target_transform);
|
| +
|
| + host_impl_->DrawLayers(&frame, gfx::FrameTime::Now());
|
| + host_impl_->DidDrawAllLayers(frame);
|
| +}
|
| +
|
| class DelegatedRendererLayerImplTestClip
|
| : public DelegatedRendererLayerImplTest {
|
| public:
|
| @@ -1051,7 +1062,7 @@ class DelegatedRendererLayerImplTestClip
|
| pass->AppendDrawQuad(color_quad.PassAs<DrawQuad>());
|
|
|
| delegated_renderer_layer->SetFrameDataForRenderPasses(
|
| - &delegated_render_passes);
|
| + 1.f, &delegated_render_passes);
|
|
|
| // The RenderPasses should be taken by the layer.
|
| EXPECT_EQ(0u, delegated_render_passes.size());
|
| @@ -1355,7 +1366,7 @@ TEST_F(DelegatedRendererLayerImplTest, InvalidRenderPassDrawQuad) {
|
| AddRenderPassQuad(pass1, missing_pass.get());
|
|
|
| delegated_renderer_layer->SetFrameDataForRenderPasses(
|
| - &delegated_render_passes);
|
| + 1.f, &delegated_render_passes);
|
|
|
| // The RenderPasses should be taken by the layer.
|
| EXPECT_EQ(0u, delegated_render_passes.size());
|
| @@ -1408,7 +1419,7 @@ TEST_F(DelegatedRendererLayerImplTest, Occlusion) {
|
| gfx::Transform());
|
| AddRenderPassQuad(pass1, pass2, 0, FilterOperations(), transform);
|
| delegated_renderer_layer_impl->SetFrameDataForRenderPasses(
|
| - &delegated_render_passes);
|
| + 1.f, &delegated_render_passes);
|
|
|
| impl.CalcDrawProps(viewport_size);
|
|
|
|
|