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/damage_tracker.h" | 5 #include "cc/trees/damage_tracker.h" |
6 | 6 |
7 #include "cc/base/math_util.h" | 7 #include "cc/base/math_util.h" |
8 #include "cc/layers/layer_impl.h" | 8 #include "cc/layers/layer_impl.h" |
9 #include "cc/output/filter_operation.h" | 9 #include "cc/output/filter_operation.h" |
10 #include "cc/output/filter_operations.h" | 10 #include "cc/output/filter_operations.h" |
11 #include "cc/test/fake_impl_proxy.h" | 11 #include "cc/test/fake_impl_proxy.h" |
12 #include "cc/test/fake_layer_tree_host_impl.h" | 12 #include "cc/test/fake_layer_tree_host_impl.h" |
13 #include "cc/test/geometry_test_utils.h" | 13 #include "cc/test/geometry_test_utils.h" |
14 #include "cc/test/test_shared_bitmap_manager.h" | 14 #include "cc/test/test_shared_bitmap_manager.h" |
15 #include "cc/test/test_task_graph_runner.h" | 15 #include "cc/test/test_task_graph_runner.h" |
16 #include "cc/trees/layer_tree_host_common.h" | 16 #include "cc/trees/layer_tree_host_common.h" |
| 17 #include "cc/trees/layer_tree_impl.h" |
17 #include "cc/trees/single_thread_proxy.h" | 18 #include "cc/trees/single_thread_proxy.h" |
18 #include "testing/gtest/include/gtest/gtest.h" | 19 #include "testing/gtest/include/gtest/gtest.h" |
19 #include "third_party/skia/include/effects/SkBlurImageFilter.h" | 20 #include "third_party/skia/include/effects/SkBlurImageFilter.h" |
20 #include "ui/gfx/geometry/quad_f.h" | 21 #include "ui/gfx/geometry/quad_f.h" |
21 #include "ui/gfx/geometry/rect_conversions.h" | 22 #include "ui/gfx/geometry/rect_conversions.h" |
22 | 23 |
23 namespace cc { | 24 namespace cc { |
24 namespace { | 25 namespace { |
25 | 26 |
26 void ExecuteCalculateDrawProperties(LayerImpl* root, | 27 void ExecuteCalculateDrawProperties(LayerImpl* root, |
(...skipping 13 matching lines...) Expand all Loading... |
40 void ClearDamageForAllSurfaces(LayerImpl* layer) { | 41 void ClearDamageForAllSurfaces(LayerImpl* layer) { |
41 if (layer->render_surface()) | 42 if (layer->render_surface()) |
42 layer->render_surface()->damage_tracker()->DidDrawDamagedArea(); | 43 layer->render_surface()->damage_tracker()->DidDrawDamagedArea(); |
43 | 44 |
44 // Recursively clear damage for any existing surface. | 45 // Recursively clear damage for any existing surface. |
45 for (size_t i = 0; i < layer->children().size(); ++i) | 46 for (size_t i = 0; i < layer->children().size(); ++i) |
46 ClearDamageForAllSurfaces(layer->children()[i]); | 47 ClearDamageForAllSurfaces(layer->children()[i]); |
47 } | 48 } |
48 | 49 |
49 void EmulateDrawingOneFrame(LayerImpl* root) { | 50 void EmulateDrawingOneFrame(LayerImpl* root) { |
| 51 root->layer_tree_impl()->property_trees()->needs_rebuild = true; |
50 // This emulates only steps that are relevant to testing the damage tracker: | 52 // This emulates only steps that are relevant to testing the damage tracker: |
51 // 1. computing the render passes and layerlists | 53 // 1. computing the render passes and layerlists |
52 // 2. updating all damage trackers in the correct order | 54 // 2. updating all damage trackers in the correct order |
53 // 3. resetting all update_rects and property_changed flags for all layers | 55 // 3. resetting all update_rects and property_changed flags for all layers |
54 // and surfaces. | 56 // and surfaces. |
55 | 57 |
56 LayerImplList render_surface_layer_list; | 58 LayerImplList render_surface_layer_list; |
57 ExecuteCalculateDrawProperties(root, &render_surface_layer_list); | 59 ExecuteCalculateDrawProperties(root, &render_surface_layer_list); |
58 | 60 |
59 // Iterate back-to-front, so that damage correctly propagates from descendant | 61 // Iterate back-to-front, so that damage correctly propagates from descendant |
(...skipping 1405 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1465 gfx::Rect root_damage_rect = | 1467 gfx::Rect root_damage_rect = |
1466 root->render_surface()->damage_tracker()->current_damage_rect(); | 1468 root->render_surface()->damage_tracker()->current_damage_rect(); |
1467 gfx::Rect damage_we_care_about = gfx::Rect(i, i); | 1469 gfx::Rect damage_we_care_about = gfx::Rect(i, i); |
1468 EXPECT_LE(damage_we_care_about.right(), root_damage_rect.right()); | 1470 EXPECT_LE(damage_we_care_about.right(), root_damage_rect.right()); |
1469 EXPECT_LE(damage_we_care_about.bottom(), root_damage_rect.bottom()); | 1471 EXPECT_LE(damage_we_care_about.bottom(), root_damage_rect.bottom()); |
1470 } | 1472 } |
1471 } | 1473 } |
1472 | 1474 |
1473 } // namespace | 1475 } // namespace |
1474 } // namespace cc | 1476 } // namespace cc |
OLD | NEW |