Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/picture_layer.h" | 5 #include "cc/layers/picture_layer.h" |
| 6 | 6 |
| 7 #include "cc/layers/content_layer_client.h" | 7 #include "cc/layers/content_layer_client.h" |
| 8 #include "cc/layers/picture_layer_impl.h" | 8 #include "cc/layers/picture_layer_impl.h" |
| 9 #include "cc/resources/resource_update_queue.h" | 9 #include "cc/resources/resource_update_queue.h" |
| 10 #include "cc/test/fake_content_layer_client.h" | |
| 10 #include "cc/test/fake_layer_tree_host.h" | 11 #include "cc/test/fake_layer_tree_host.h" |
| 11 #include "cc/test/fake_picture_layer_impl.h" | 12 #include "cc/test/fake_picture_layer_impl.h" |
| 12 #include "cc/test/fake_proxy.h" | 13 #include "cc/test/fake_proxy.h" |
| 13 #include "cc/test/impl_side_painting_settings.h" | 14 #include "cc/test/impl_side_painting_settings.h" |
| 14 #include "cc/trees/occlusion_tracker.h" | 15 #include "cc/trees/occlusion_tracker.h" |
| 15 #include "cc/trees/single_thread_proxy.h" | 16 #include "cc/trees/single_thread_proxy.h" |
| 16 #include "testing/gtest/include/gtest/gtest.h" | 17 #include "testing/gtest/include/gtest/gtest.h" |
| 17 | 18 |
| 18 namespace cc { | 19 namespace cc { |
| 19 namespace { | 20 namespace { |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 59 ImplSidePaintingSettings(), &proxy, &shared_bitmap_manager); | 60 ImplSidePaintingSettings(), &proxy, &shared_bitmap_manager); |
| 60 host_impl.CreatePendingTree(); | 61 host_impl.CreatePendingTree(); |
| 61 scoped_ptr<FakePictureLayerImpl> layer_impl = | 62 scoped_ptr<FakePictureLayerImpl> layer_impl = |
| 62 FakePictureLayerImpl::Create(host_impl.pending_tree(), 1); | 63 FakePictureLayerImpl::Create(host_impl.pending_tree(), 1); |
| 63 | 64 |
| 64 layer->PushPropertiesTo(layer_impl.get()); | 65 layer->PushPropertiesTo(layer_impl.get()); |
| 65 EXPECT_FALSE(layer_impl->CanHaveTilings()); | 66 EXPECT_FALSE(layer_impl->CanHaveTilings()); |
| 66 EXPECT_TRUE(layer_impl->bounds() == gfx::Size(0, 0)); | 67 EXPECT_TRUE(layer_impl->bounds() == gfx::Size(0, 0)); |
| 67 EXPECT_EQ(gfx::Size(), layer_impl->pile()->tiling_size()); | 68 EXPECT_EQ(gfx::Size(), layer_impl->pile()->tiling_size()); |
| 68 EXPECT_FALSE(layer_impl->pile()->HasRecordings()); | 69 EXPECT_FALSE(layer_impl->pile()->HasRecordings()); |
| 70 EXPECT_TRUE(layer_impl->pile()->is_solid_color()); | |
|
danakj
2014/09/19 20:44:28
do we care if it's solid color when it's empty? is
hendrikw
2014/09/19 22:27:13
Acknowledged.
| |
| 69 } | 71 } |
| 70 } | 72 } |
| 71 | 73 |
| 72 TEST(PictureLayerTest, SuitableForGpuRasterization) { | 74 TEST(PictureLayerTest, SuitableForGpuRasterization) { |
| 73 MockContentLayerClient client; | 75 MockContentLayerClient client; |
| 74 scoped_refptr<PictureLayer> layer = PictureLayer::Create(&client); | 76 scoped_refptr<PictureLayer> layer = PictureLayer::Create(&client); |
| 75 PicturePile* pile = layer->GetPicturePileForTesting(); | 77 PicturePile* pile = layer->GetPicturePileForTesting(); |
| 76 | 78 |
| 77 // Layer is suitable for gpu rasterization by default. | 79 // Layer is suitable for gpu rasterization by default. |
| 78 EXPECT_TRUE(pile->is_suitable_for_gpu_rasterization()); | 80 EXPECT_TRUE(pile->is_suitable_for_gpu_rasterization()); |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 92 scoped_ptr<FakeLayerTreeHost> host = FakeLayerTreeHost::Create(settings); | 94 scoped_ptr<FakeLayerTreeHost> host = FakeLayerTreeHost::Create(settings); |
| 93 host->SetRootLayer(layer); | 95 host->SetRootLayer(layer); |
| 94 EXPECT_EQ(Picture::RECORD_NORMALLY, layer->RecordingMode()); | 96 EXPECT_EQ(Picture::RECORD_NORMALLY, layer->RecordingMode()); |
| 95 | 97 |
| 96 settings.recording_mode = LayerTreeSettings::RecordWithSkRecord; | 98 settings.recording_mode = LayerTreeSettings::RecordWithSkRecord; |
| 97 host = FakeLayerTreeHost::Create(settings); | 99 host = FakeLayerTreeHost::Create(settings); |
| 98 host->SetRootLayer(layer); | 100 host->SetRootLayer(layer); |
| 99 EXPECT_EQ(Picture::RECORD_WITH_SKRECORD, layer->RecordingMode()); | 101 EXPECT_EQ(Picture::RECORD_WITH_SKRECORD, layer->RecordingMode()); |
| 100 } | 102 } |
| 101 | 103 |
| 104 TEST(PictureLayerTest, SolidColorAnalysisForPictureLayer) { | |
|
danakj
2014/09/19 20:44:28
should this test move to picture_pile_unittest.cc?
hendrikw
2014/09/19 22:27:13
It was testing that the solid state was being tran
| |
| 105 FakeContentLayerClient client; | |
| 106 scoped_refptr<PictureLayer> layer = PictureLayer::Create(&client); | |
| 107 scoped_ptr<FakeLayerTreeHost> host = FakeLayerTreeHost::Create(); | |
| 108 host->SetRootLayer(layer); | |
| 109 PicturePile* pile = layer->GetPicturePileForTesting(); | |
| 110 pile->tiling().SetTilingSize(pile->tiling().max_texture_size()); | |
| 111 | |
| 112 FakeProxy proxy; | |
| 113 DebugScopedSetImplThread impl_thread(&proxy); | |
| 114 | |
| 115 TestSharedBitmapManager shared_bitmap_manager; | |
| 116 FakeLayerTreeHostImpl host_impl( | |
| 117 ImplSidePaintingSettings(), &proxy, &shared_bitmap_manager); | |
| 118 host_impl.CreatePendingTree(); | |
| 119 scoped_ptr<FakePictureLayerImpl> layer_impl = | |
| 120 FakePictureLayerImpl::Create(host_impl.pending_tree(), 1); | |
| 121 | |
| 122 gfx::Size tiling_size = pile->tiling_size(); | |
| 123 gfx::Rect tiling_rect = gfx::Rect(tiling_size); | |
| 124 int frame_number = 0; | |
| 125 FakeRenderingStatsInstrumentation stats_instrumentation; | |
| 126 | |
| 127 Region invalidation1(tiling_rect); | |
| 128 pile->UpdateAndExpandInvalidation(&client, | |
| 129 &invalidation1, | |
| 130 SK_ColorWHITE, | |
| 131 false, | |
| 132 false, | |
| 133 tiling_size, | |
| 134 tiling_rect, | |
| 135 frame_number++, | |
| 136 Picture::RECORD_NORMALLY, | |
| 137 &stats_instrumentation); | |
| 138 | |
| 139 // We haven't drawn anything yet, so it should be solid. | |
| 140 EXPECT_TRUE(pile->is_solid_color()); | |
| 141 layer->PushPropertiesTo(layer_impl.get()); | |
| 142 EXPECT_TRUE(layer_impl->pile()->is_solid_color()); | |
| 143 | |
| 144 // Draw a rectangle that doesn't cover the viewport. | |
| 145 gfx::Rect smallRect = tiling_rect; | |
| 146 smallRect.Inset(10, 10, 10, 10); | |
| 147 SkPaint paint; | |
| 148 paint.setColor(SK_ColorCYAN); | |
| 149 client.add_draw_rect(smallRect, paint); | |
| 150 Region invalidation2(tiling_rect); | |
| 151 pile->UpdateAndExpandInvalidation(&client, | |
| 152 &invalidation2, | |
| 153 SK_ColorWHITE, | |
| 154 false, | |
| 155 false, | |
| 156 tiling_size, | |
| 157 tiling_rect, | |
| 158 frame_number++, | |
| 159 Picture::RECORD_NORMALLY, | |
| 160 &stats_instrumentation); | |
| 161 | |
| 162 // Since the rectangle doesn't cover the entire layer, we should no be solid | |
| 163 EXPECT_FALSE(pile->is_solid_color()); | |
| 164 layer->PushPropertiesTo(layer_impl.get()); | |
| 165 EXPECT_FALSE(layer_impl->pile()->is_solid_color()); | |
|
danakj
2014/09/19 20:44:28
you could just CreateFrom() another pile and verif
| |
| 166 | |
| 167 // Draw a rectangle that covers the viewport. | |
| 168 client.add_draw_rect(tiling_rect, paint); | |
| 169 Region invalidation3(tiling_rect); | |
| 170 pile->UpdateAndExpandInvalidation(&client, | |
| 171 &invalidation3, | |
| 172 SK_ColorWHITE, | |
| 173 false, | |
| 174 false, | |
| 175 tiling_size, | |
| 176 tiling_rect, | |
| 177 frame_number++, | |
| 178 Picture::RECORD_NORMALLY, | |
| 179 &stats_instrumentation); | |
| 180 | |
| 181 // Since the rectangle doesn't cover the entire layer, we should no be solid | |
| 182 EXPECT_TRUE(pile->is_solid_color()); | |
| 183 layer->PushPropertiesTo(layer_impl.get()); | |
| 184 // EXPECT_EQ(0, layer->Tiling) | |
| 185 // EXPECT_TRUE(layer_impl->pile()->is_solid_color()); | |
|
danakj
2014/09/19 20:44:28
leftovers
| |
| 186 } | |
| 187 | |
| 102 } // namespace | 188 } // namespace |
| 103 } // namespace cc | 189 } // namespace cc |
| OLD | NEW |