OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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/tiled_layer_impl.h" | 5 #include "cc/layers/tiled_layer_impl.h" |
6 | 6 |
7 #include "cc/layers/append_quads_data.h" | 7 #include "cc/layers/append_quads_data.h" |
8 #include "cc/quads/tile_draw_quad.h" | 8 #include "cc/quads/tile_draw_quad.h" |
9 #include "cc/resources/layer_tiling_data.h" | 9 #include "cc/resources/layer_tiling_data.h" |
10 #include "cc/test/fake_impl_proxy.h" | 10 #include "cc/test/fake_impl_proxy.h" |
11 #include "cc/test/fake_layer_tree_host_impl.h" | 11 #include "cc/test/fake_layer_tree_host_impl.h" |
12 #include "cc/test/layer_test_common.h" | 12 #include "cc/test/layer_test_common.h" |
13 #include "cc/test/mock_quad_culler.h" | 13 #include "cc/test/mock_quad_culler.h" |
14 #include "cc/trees/single_thread_proxy.h" | 14 #include "cc/trees/single_thread_proxy.h" |
15 #include "testing/gmock/include/gmock/gmock.h" | 15 #include "testing/gmock/include/gmock/gmock.h" |
16 #include "testing/gtest/include/gtest/gtest.h" | 16 #include "testing/gtest/include/gtest/gtest.h" |
17 | 17 |
18 namespace cc { | 18 namespace cc { |
19 namespace { | 19 namespace { |
20 | 20 |
21 class TiledLayerImplTest : public testing::Test { | 21 class TiledLayerImplTest : public testing::Test { |
22 public: | 22 public: |
23 TiledLayerImplTest() : host_impl_(&proxy_) {} | 23 TiledLayerImplTest() : host_impl_(&proxy_) {} |
24 | 24 |
25 scoped_ptr<TiledLayerImpl> CreateLayerNoTiles( | 25 scoped_ptr<TiledLayerImpl> CreateLayerNoTiles( |
26 gfx::Size tile_size, | 26 const gfx::Size& tile_size, |
27 gfx::Size layer_size, | 27 const gfx::Size& layer_size, |
28 LayerTilingData::BorderTexelOption border_texels) { | 28 LayerTilingData::BorderTexelOption border_texels) { |
29 scoped_ptr<TiledLayerImpl> layer = | 29 scoped_ptr<TiledLayerImpl> layer = |
30 TiledLayerImpl::Create(host_impl_.active_tree(), 1); | 30 TiledLayerImpl::Create(host_impl_.active_tree(), 1); |
31 scoped_ptr<LayerTilingData> tiler = | 31 scoped_ptr<LayerTilingData> tiler = |
32 LayerTilingData::Create(tile_size, border_texels); | 32 LayerTilingData::Create(tile_size, border_texels); |
33 tiler->SetBounds(layer_size); | 33 tiler->SetBounds(layer_size); |
34 layer->SetTilingData(*tiler); | 34 layer->SetTilingData(*tiler); |
35 layer->set_skips_draw(false); | 35 layer->set_skips_draw(false); |
36 layer->draw_properties().visible_content_rect = | 36 layer->draw_properties().visible_content_rect = |
37 gfx::Rect(layer_size); | 37 gfx::Rect(layer_size); |
38 layer->draw_properties().opacity = 1; | 38 layer->draw_properties().opacity = 1; |
39 layer->SetBounds(layer_size); | 39 layer->SetBounds(layer_size); |
40 layer->SetContentBounds(layer_size); | 40 layer->SetContentBounds(layer_size); |
41 layer->CreateRenderSurface(); | 41 layer->CreateRenderSurface(); |
42 layer->draw_properties().render_target = layer.get(); | 42 layer->draw_properties().render_target = layer.get(); |
43 return layer.Pass(); | 43 return layer.Pass(); |
44 } | 44 } |
45 | 45 |
46 // Create a default tiled layer with textures for all tiles and a default | 46 // Create a default tiled layer with textures for all tiles and a default |
47 // visibility of the entire layer size. | 47 // visibility of the entire layer size. |
48 scoped_ptr<TiledLayerImpl> CreateLayer( | 48 scoped_ptr<TiledLayerImpl> CreateLayer( |
49 gfx::Size tile_size, | 49 const gfx::Size& tile_size, |
50 gfx::Size layer_size, | 50 const gfx::Size& layer_size, |
51 LayerTilingData::BorderTexelOption border_texels) { | 51 LayerTilingData::BorderTexelOption border_texels) { |
52 scoped_ptr<TiledLayerImpl> layer = | 52 scoped_ptr<TiledLayerImpl> layer = |
53 CreateLayerNoTiles(tile_size, layer_size, border_texels); | 53 CreateLayerNoTiles(tile_size, layer_size, border_texels); |
54 | 54 |
55 layer->SetDrawsContent(true); | 55 layer->SetDrawsContent(true); |
56 | 56 |
57 ResourceProvider::ResourceId resource_id = 1; | 57 ResourceProvider::ResourceId resource_id = 1; |
58 for (int i = 0; i < layer->TilingForTesting()->num_tiles_x(); ++i) { | 58 for (int i = 0; i < layer->TilingForTesting()->num_tiles_x(); ++i) { |
59 for (int j = 0; j < layer->TilingForTesting()->num_tiles_y(); ++j) { | 59 for (int j = 0; j < layer->TilingForTesting()->num_tiles_y(); ++j) { |
60 gfx::Rect opaque_rect( | 60 gfx::Rect opaque_rect( |
61 layer->TilingForTesting()->tile_bounds(i, j).origin(), | 61 layer->TilingForTesting()->tile_bounds(i, j).origin(), |
62 gfx::Size(1, 1)); | 62 gfx::Size(1, 1)); |
63 layer->PushTileProperties(i, j, resource_id++, opaque_rect, false); | 63 layer->PushTileProperties(i, j, resource_id++, opaque_rect, false); |
64 } | 64 } |
65 } | 65 } |
66 | 66 |
67 return layer.Pass(); | 67 return layer.Pass(); |
68 } | 68 } |
69 | 69 |
70 void GetQuads(QuadList* quads, | 70 void GetQuads(QuadList* quads, |
71 SharedQuadStateList* shared_states, | 71 SharedQuadStateList* shared_states, |
72 gfx::Size tile_size, | 72 const gfx::Size& tile_size, |
73 gfx::Size layer_size, | 73 const gfx::Size& layer_size, |
74 LayerTilingData::BorderTexelOption border_texel_option, | 74 LayerTilingData::BorderTexelOption border_texel_option, |
75 const gfx::Rect& visible_content_rect) { | 75 const gfx::Rect& visible_content_rect) { |
76 scoped_ptr<TiledLayerImpl> layer = | 76 scoped_ptr<TiledLayerImpl> layer = |
77 CreateLayer(tile_size, layer_size, border_texel_option); | 77 CreateLayer(tile_size, layer_size, border_texel_option); |
78 layer->draw_properties().visible_content_rect = visible_content_rect; | 78 layer->draw_properties().visible_content_rect = visible_content_rect; |
79 layer->SetBounds(layer_size); | 79 layer->SetBounds(layer_size); |
80 | 80 |
81 MockQuadCuller quad_culler(quads, shared_states); | 81 MockQuadCuller quad_culler(quads, shared_states); |
82 AppendQuadsData data; | 82 AppendQuadsData data; |
83 layer->AppendQuads(&quad_culler, &data); | 83 layer->AppendQuads(&quad_culler, &data); |
(...skipping 226 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
310 scoped_ptr<TiledLayerImpl> layer = | 310 scoped_ptr<TiledLayerImpl> layer = |
311 CreateLayer(tile_size, layer_size, LayerTilingData::NO_BORDER_TEXELS); | 311 CreateLayer(tile_size, layer_size, LayerTilingData::NO_BORDER_TEXELS); |
312 | 312 |
313 EXPECT_EQ(0u, layer->ContentsResourceId()); | 313 EXPECT_EQ(0u, layer->ContentsResourceId()); |
314 EXPECT_EQ(0, layer->TilingForTesting()->num_tiles_x()); | 314 EXPECT_EQ(0, layer->TilingForTesting()->num_tiles_x()); |
315 EXPECT_EQ(0, layer->TilingForTesting()->num_tiles_y()); | 315 EXPECT_EQ(0, layer->TilingForTesting()->num_tiles_y()); |
316 } | 316 } |
317 | 317 |
318 } // namespace | 318 } // namespace |
319 } // namespace cc | 319 } // namespace cc |
OLD | NEW |