OLD | NEW |
1 // Copyright 2011 The Chromium Authors. All rights reserved. | 1 // Copyright 2011 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/trees/layer_tree_host_common.h" | 5 #include "cc/trees/layer_tree_host_common.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include <algorithm> | 9 #include <algorithm> |
10 #include <memory> | 10 #include <memory> |
(...skipping 329 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
340 LayerImpl::Create(host_impl.active_tree(), 3)); | 340 LayerImpl::Create(host_impl.active_tree(), 3)); |
341 SetLayerPropertiesForTesting(root.get(), identity_matrix, gfx::Point3F(), | 341 SetLayerPropertiesForTesting(root.get(), identity_matrix, gfx::Point3F(), |
342 gfx::PointF(), gfx::Size(3, 4), true, false, | 342 gfx::PointF(), gfx::Size(3, 4), true, false, |
343 false); | 343 false); |
344 root->AddChild(std::move(clip_layer_scoped_ptr)); | 344 root->AddChild(std::move(clip_layer_scoped_ptr)); |
345 root->SetHasRenderSurface(true); | 345 root->SetHasRenderSurface(true); |
346 LayerImpl* root_layer = root.get(); | 346 LayerImpl* root_layer = root.get(); |
347 host_impl.active_tree()->SetRootLayer(std::move(root)); | 347 host_impl.active_tree()->SetRootLayer(std::move(root)); |
348 | 348 |
349 ExecuteCalculateDrawProperties(root_layer, kDeviceScale, page_scale, | 349 ExecuteCalculateDrawProperties(root_layer, kDeviceScale, page_scale, |
350 scroll_layer->parent()); | 350 scroll_layer->test_properties()->parent); |
351 gfx::Transform expected_transform = identity_matrix; | 351 gfx::Transform expected_transform = identity_matrix; |
352 gfx::PointF sub_layer_screen_position = kScrollLayerPosition - kScrollDelta; | 352 gfx::PointF sub_layer_screen_position = kScrollLayerPosition - kScrollDelta; |
353 expected_transform.Translate(MathUtil::Round(sub_layer_screen_position.x() * | 353 expected_transform.Translate(MathUtil::Round(sub_layer_screen_position.x() * |
354 page_scale * kDeviceScale), | 354 page_scale * kDeviceScale), |
355 MathUtil::Round(sub_layer_screen_position.y() * | 355 MathUtil::Round(sub_layer_screen_position.y() * |
356 page_scale * kDeviceScale)); | 356 page_scale * kDeviceScale)); |
357 expected_transform.Scale(page_scale * kDeviceScale, | 357 expected_transform.Scale(page_scale * kDeviceScale, |
358 page_scale * kDeviceScale); | 358 page_scale * kDeviceScale); |
359 EXPECT_TRANSFORMATION_MATRIX_EQ(expected_transform, | 359 EXPECT_TRANSFORMATION_MATRIX_EQ(expected_transform, |
360 sublayer->DrawTransform()); | 360 sublayer->DrawTransform()); |
361 EXPECT_TRANSFORMATION_MATRIX_EQ(expected_transform, | 361 EXPECT_TRANSFORMATION_MATRIX_EQ(expected_transform, |
362 sublayer->ScreenSpaceTransform()); | 362 sublayer->ScreenSpaceTransform()); |
363 | 363 |
364 gfx::Transform arbitrary_translate; | 364 gfx::Transform arbitrary_translate; |
365 const float kTranslateX = 10.6f; | 365 const float kTranslateX = 10.6f; |
366 const float kTranslateY = 20.6f; | 366 const float kTranslateY = 20.6f; |
367 arbitrary_translate.Translate(kTranslateX, kTranslateY); | 367 arbitrary_translate.Translate(kTranslateX, kTranslateY); |
368 SetLayerPropertiesForTesting(scroll_layer, arbitrary_translate, | 368 SetLayerPropertiesForTesting(scroll_layer, arbitrary_translate, |
369 gfx::Point3F(), gfx::PointF(), gfx::Size(10, 20), | 369 gfx::Point3F(), gfx::PointF(), gfx::Size(10, 20), |
370 true, false, false); | 370 true, false, false); |
371 root_layer->layer_tree_impl()->property_trees()->needs_rebuild = true; | 371 root_layer->layer_tree_impl()->property_trees()->needs_rebuild = true; |
372 ExecuteCalculateDrawProperties(root_layer, kDeviceScale, page_scale, | 372 ExecuteCalculateDrawProperties(root_layer, kDeviceScale, page_scale, |
373 scroll_layer->parent()); | 373 scroll_layer->test_properties()->parent); |
374 expected_transform.MakeIdentity(); | 374 expected_transform.MakeIdentity(); |
375 expected_transform.Translate( | 375 expected_transform.Translate( |
376 MathUtil::Round(kTranslateX * page_scale * kDeviceScale + | 376 MathUtil::Round(kTranslateX * page_scale * kDeviceScale + |
377 sub_layer_screen_position.x() * page_scale * | 377 sub_layer_screen_position.x() * page_scale * |
378 kDeviceScale), | 378 kDeviceScale), |
379 MathUtil::Round(kTranslateY * page_scale * kDeviceScale + | 379 MathUtil::Round(kTranslateY * page_scale * kDeviceScale + |
380 sub_layer_screen_position.y() * page_scale * | 380 sub_layer_screen_position.y() * page_scale * |
381 kDeviceScale)); | 381 kDeviceScale)); |
382 expected_transform.Scale(page_scale * kDeviceScale, | 382 expected_transform.Scale(page_scale * kDeviceScale, |
383 page_scale * kDeviceScale); | 383 page_scale * kDeviceScale); |
384 EXPECT_TRANSFORMATION_MATRIX_EQ(expected_transform, | 384 EXPECT_TRANSFORMATION_MATRIX_EQ(expected_transform, |
385 sublayer->DrawTransform()); | 385 sublayer->DrawTransform()); |
386 | 386 |
387 // Test that page scale is updated even when we don't rebuild property trees. | 387 // Test that page scale is updated even when we don't rebuild property trees. |
388 page_scale = 1.888f; | 388 page_scale = 1.888f; |
389 root_layer->layer_tree_impl()->SetViewportLayersFromIds( | 389 root_layer->layer_tree_impl()->SetViewportLayersFromIds( |
390 Layer::INVALID_ID, scroll_layer->parent()->id(), Layer::INVALID_ID, | 390 Layer::INVALID_ID, scroll_layer->test_properties()->parent->id(), |
391 Layer::INVALID_ID); | 391 Layer::INVALID_ID, Layer::INVALID_ID); |
392 root_layer->layer_tree_impl()->SetPageScaleOnActiveTree(page_scale); | 392 root_layer->layer_tree_impl()->SetPageScaleOnActiveTree(page_scale); |
393 EXPECT_FALSE(root_layer->layer_tree_impl()->property_trees()->needs_rebuild); | 393 EXPECT_FALSE(root_layer->layer_tree_impl()->property_trees()->needs_rebuild); |
394 ExecuteCalculateDrawProperties(root_layer, kDeviceScale, page_scale, | 394 ExecuteCalculateDrawProperties(root_layer, kDeviceScale, page_scale, |
395 scroll_layer->parent()); | 395 scroll_layer->test_properties()->parent); |
396 | 396 |
397 expected_transform.MakeIdentity(); | 397 expected_transform.MakeIdentity(); |
398 expected_transform.Translate( | 398 expected_transform.Translate( |
399 MathUtil::Round(kTranslateX * page_scale * kDeviceScale + | 399 MathUtil::Round(kTranslateX * page_scale * kDeviceScale + |
400 sub_layer_screen_position.x() * page_scale * | 400 sub_layer_screen_position.x() * page_scale * |
401 kDeviceScale), | 401 kDeviceScale), |
402 MathUtil::Round(kTranslateY * page_scale * kDeviceScale + | 402 MathUtil::Round(kTranslateY * page_scale * kDeviceScale + |
403 sub_layer_screen_position.y() * page_scale * | 403 sub_layer_screen_position.y() * page_scale * |
404 kDeviceScale)); | 404 kDeviceScale)); |
405 expected_transform.Scale(page_scale * kDeviceScale, | 405 expected_transform.Scale(page_scale * kDeviceScale, |
(...skipping 400 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
806 gfx::Point3F(2.5f, 0.f, 0.f), gfx::PointF(), | 806 gfx::Point3F(2.5f, 0.f, 0.f), gfx::PointF(), |
807 gfx::Size(10, 10), true, false, false); | 807 gfx::Size(10, 10), true, false, false); |
808 SetLayerPropertiesForTesting(replica_of_rs1.get(), replica_layer_transform, | 808 SetLayerPropertiesForTesting(replica_of_rs1.get(), replica_layer_transform, |
809 gfx::Point3F(2.5f, 0.f, 0.f), gfx::PointF(), | 809 gfx::Point3F(2.5f, 0.f, 0.f), gfx::PointF(), |
810 gfx::Size(), true, false, false); | 810 gfx::Size(), true, false, false); |
811 SetLayerPropertiesForTesting(replica_of_rs2.get(), replica_layer_transform, | 811 SetLayerPropertiesForTesting(replica_of_rs2.get(), replica_layer_transform, |
812 gfx::Point3F(2.5f, 0.f, 0.f), gfx::PointF(), | 812 gfx::Point3F(2.5f, 0.f, 0.f), gfx::PointF(), |
813 gfx::Size(), true, false, false); | 813 gfx::Size(), true, false, false); |
814 | 814 |
815 // We need to set parent on replica layers for property tree building. | 815 // We need to set parent on replica layers for property tree building. |
816 replica_of_rs1->SetParent(render_surface1); | 816 replica_of_rs1->test_properties()->parent = render_surface1; |
817 replica_of_rs2->SetParent(render_surface2); | 817 replica_of_rs2->test_properties()->parent = render_surface2; |
818 render_surface1->test_properties()->SetReplicaLayer( | 818 render_surface1->test_properties()->SetReplicaLayer( |
819 std::move(replica_of_rs1)); | 819 std::move(replica_of_rs1)); |
820 render_surface2->test_properties()->SetReplicaLayer( | 820 render_surface2->test_properties()->SetReplicaLayer( |
821 std::move(replica_of_rs2)); | 821 std::move(replica_of_rs2)); |
822 ExecuteCalculateDrawProperties(root); | 822 ExecuteCalculateDrawProperties(root); |
823 | 823 |
824 // Only layers that are associated with render surfaces should have an actual | 824 // Only layers that are associated with render surfaces should have an actual |
825 // RenderSurface() value. | 825 // RenderSurface() value. |
826 ASSERT_TRUE(root->render_surface()); | 826 ASSERT_TRUE(root->render_surface()); |
827 ASSERT_FALSE(child_of_root->render_surface()); | 827 ASSERT_FALSE(child_of_root->render_surface()); |
(...skipping 4097 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4925 | 4925 |
4926 gfx::Transform replica_transform; | 4926 gfx::Transform replica_transform; |
4927 replica_transform.Scale(1.0, -1.0); | 4927 replica_transform.Scale(1.0, -1.0); |
4928 | 4928 |
4929 std::unique_ptr<LayerImpl> replica = | 4929 std::unique_ptr<LayerImpl> replica = |
4930 LayerImpl::Create(host_impl()->active_tree(), 7); | 4930 LayerImpl::Create(host_impl()->active_tree(), 7); |
4931 SetLayerPropertiesForTesting(replica.get(), replica_transform, gfx::Point3F(), | 4931 SetLayerPropertiesForTesting(replica.get(), replica_transform, gfx::Point3F(), |
4932 gfx::PointF(2.f, 2.f), gfx::Size(10, 10), false, | 4932 gfx::PointF(2.f, 2.f), gfx::Size(10, 10), false, |
4933 true, false); | 4933 true, false); |
4934 // We need to set parent on replica layer for property tree building. | 4934 // We need to set parent on replica layer for property tree building. |
4935 replica->SetParent(child); | 4935 replica->test_properties()->parent = child; |
4936 child->test_properties()->SetReplicaLayer(std::move(replica)); | 4936 child->test_properties()->SetReplicaLayer(std::move(replica)); |
4937 | 4937 |
4938 // This layer should end up in the same surface as child, with the same draw | 4938 // This layer should end up in the same surface as child, with the same draw |
4939 // and screen space transforms. | 4939 // and screen space transforms. |
4940 LayerImpl* duplicate_child_non_owner = AddChild<LayerImpl>(child); | 4940 LayerImpl* duplicate_child_non_owner = AddChild<LayerImpl>(child); |
4941 duplicate_child_non_owner->SetDrawsContent(true); | 4941 duplicate_child_non_owner->SetDrawsContent(true); |
4942 SetLayerPropertiesForTesting(duplicate_child_non_owner, identity_matrix, | 4942 SetLayerPropertiesForTesting(duplicate_child_non_owner, identity_matrix, |
4943 gfx::Point3F(), gfx::PointF(), gfx::Size(10, 10), | 4943 gfx::Point3F(), gfx::PointF(), gfx::Size(10, 10), |
4944 false, true, false); | 4944 false, true, false); |
4945 | 4945 |
(...skipping 4774 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
9720 EXPECT_EQ(gfx::Rect(20, 20), mask->visible_layer_rect()); | 9720 EXPECT_EQ(gfx::Rect(20, 20), mask->visible_layer_rect()); |
9721 } | 9721 } |
9722 | 9722 |
9723 TEST_F(LayerTreeHostCommonTest, ReplicaMaskLayerDrawProperties) { | 9723 TEST_F(LayerTreeHostCommonTest, ReplicaMaskLayerDrawProperties) { |
9724 // Tests that a replica mask layer's draw properties are computed correctly. | 9724 // Tests that a replica mask layer's draw properties are computed correctly. |
9725 LayerImpl* root = root_layer(); | 9725 LayerImpl* root = root_layer(); |
9726 LayerImpl* child = AddChild<LayerImpl>(root); | 9726 LayerImpl* child = AddChild<LayerImpl>(root); |
9727 child->test_properties()->SetReplicaLayer( | 9727 child->test_properties()->SetReplicaLayer( |
9728 LayerImpl::Create(root->layer_tree_impl(), 100)); | 9728 LayerImpl::Create(root->layer_tree_impl(), 100)); |
9729 LayerImpl* replica = child->test_properties()->replica_layer; | 9729 LayerImpl* replica = child->test_properties()->replica_layer; |
9730 replica->SetParent(child); | 9730 replica->test_properties()->parent = child; |
9731 replica->test_properties()->SetMaskLayer( | 9731 replica->test_properties()->SetMaskLayer( |
9732 LayerImpl::Create(root->layer_tree_impl(), 200)); | 9732 LayerImpl::Create(root->layer_tree_impl(), 200)); |
9733 LayerImpl* replica_mask = replica->test_properties()->mask_layer; | 9733 LayerImpl* replica_mask = replica->test_properties()->mask_layer; |
9734 | 9734 |
9735 const gfx::Transform identity_matrix; | 9735 const gfx::Transform identity_matrix; |
9736 gfx::Transform transform; | 9736 gfx::Transform transform; |
9737 transform.Translate(10, 10); | 9737 transform.Translate(10, 10); |
9738 | 9738 |
9739 gfx::PointF replica_position(3.f, 3.f); | 9739 gfx::PointF replica_position(3.f, 3.f); |
9740 | 9740 |
(...skipping 520 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
10261 EXPECT_EQ(scroll_child6.id, grand_child10->scroll_tree_index()); | 10261 EXPECT_EQ(scroll_child6.id, grand_child10->scroll_tree_index()); |
10262 EXPECT_EQ(scroll_root1.id, parent3->scroll_tree_index()); | 10262 EXPECT_EQ(scroll_root1.id, parent3->scroll_tree_index()); |
10263 EXPECT_EQ(scroll_child7.id, child8->scroll_tree_index()); | 10263 EXPECT_EQ(scroll_child7.id, child8->scroll_tree_index()); |
10264 EXPECT_EQ(scroll_root1.id, parent4->scroll_tree_index()); | 10264 EXPECT_EQ(scroll_root1.id, parent4->scroll_tree_index()); |
10265 EXPECT_EQ(scroll_root1.id, child9->scroll_tree_index()); | 10265 EXPECT_EQ(scroll_root1.id, child9->scroll_tree_index()); |
10266 EXPECT_EQ(scroll_root1.id, grand_child12->scroll_tree_index()); | 10266 EXPECT_EQ(scroll_root1.id, grand_child12->scroll_tree_index()); |
10267 } | 10267 } |
10268 | 10268 |
10269 } // namespace | 10269 } // namespace |
10270 } // namespace cc | 10270 } // namespace cc |
OLD | NEW |