| 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/tiled_layer_impl.h" | 5 #include "cc/tiled_layer_impl.h" |
| 6 | 6 |
| 7 #include "cc/append_quads_data.h" | 7 #include "cc/append_quads_data.h" |
| 8 #include "cc/layer_tiling_data.h" | 8 #include "cc/layer_tiling_data.h" |
| 9 #include "cc/single_thread_proxy.h" | 9 #include "cc/single_thread_proxy.h" |
| 10 #include "cc/test/fake_impl_proxy.h" |
| 11 #include "cc/test/fake_layer_tree_host_impl.h" |
| 10 #include "cc/test/layer_test_common.h" | 12 #include "cc/test/layer_test_common.h" |
| 11 #include "cc/test/mock_quad_culler.h" | 13 #include "cc/test/mock_quad_culler.h" |
| 12 #include "cc/tile_draw_quad.h" | 14 #include "cc/tile_draw_quad.h" |
| 13 #include "testing/gmock/include/gmock/gmock.h" | 15 #include "testing/gmock/include/gmock/gmock.h" |
| 14 #include "testing/gtest/include/gtest/gtest.h" | 16 #include "testing/gtest/include/gtest/gtest.h" |
| 15 | 17 |
| 16 using namespace LayerTestCommon; | 18 using namespace LayerTestCommon; |
| 17 | 19 |
| 18 namespace cc { | 20 namespace cc { |
| 21 |
| 19 namespace { | 22 namespace { |
| 20 | 23 |
| 21 // Create a default tiled layer with textures for all tiles and a default | 24 class TiledLayerImplTest : public testing::Test |
| 22 // visibility of the entire layer size. | |
| 23 static scoped_ptr<TiledLayerImpl> createLayer(const gfx::Size& tileSize, const g
fx::Size& layerSize, LayerTilingData::BorderTexelOption borderTexels) | |
| 24 { | 25 { |
| 25 scoped_ptr<TiledLayerImpl> layer = TiledLayerImpl::create(1); | 26 public: |
| 26 scoped_ptr<LayerTilingData> tiler = LayerTilingData::create(tileSize, border
Texels); | 27 TiledLayerImplTest() |
| 27 tiler->setBounds(layerSize); | 28 : m_hostImpl(&m_proxy) |
| 28 layer->setTilingData(*tiler); | 29 { |
| 29 layer->setSkipsDraw(false); | 30 } |
| 30 layer->drawProperties().visible_content_rect = gfx::Rect(gfx::Point(), layer
Size); | |
| 31 layer->drawProperties().opacity = 1; | |
| 32 layer->setBounds(layerSize); | |
| 33 layer->setContentBounds(layerSize); | |
| 34 layer->createRenderSurface(); | |
| 35 layer->drawProperties().render_target = layer.get(); | |
| 36 | 31 |
| 37 ResourceProvider::ResourceId resourceId = 1; | 32 // Create a default tiled layer with textures for all tiles and a default |
| 38 for (int i = 0; i < tiler->numTilesX(); ++i) | 33 // visibility of the entire layer size. |
| 39 for (int j = 0; j < tiler->numTilesY(); ++j) | 34 scoped_ptr<TiledLayerImpl> createLayer(const gfx::Size& tileSize, const gfx:
:Size& layerSize, LayerTilingData::BorderTexelOption borderTexels) |
| 40 layer->pushTileProperties(i, j, resourceId++, gfx::Rect(0, 0, 1, 1),
false); | 35 { |
| 36 scoped_ptr<TiledLayerImpl> layer = TiledLayerImpl::create(&m_hostImpl, 1
); |
| 37 scoped_ptr<LayerTilingData> tiler = LayerTilingData::create(tileSize, bo
rderTexels); |
| 38 tiler->setBounds(layerSize); |
| 39 layer->setTilingData(*tiler); |
| 40 layer->setSkipsDraw(false); |
| 41 layer->drawProperties().visible_content_rect = gfx::Rect(gfx::Point(), l
ayerSize); |
| 42 layer->drawProperties().opacity = 1; |
| 43 layer->setBounds(layerSize); |
| 44 layer->setContentBounds(layerSize); |
| 45 layer->createRenderSurface(); |
| 46 layer->drawProperties().render_target = layer.get(); |
| 41 | 47 |
| 42 return layer.Pass(); | 48 ResourceProvider::ResourceId resourceId = 1; |
| 43 } | 49 for (int i = 0; i < tiler->numTilesX(); ++i) |
| 50 for (int j = 0; j < tiler->numTilesY(); ++j) |
| 51 layer->pushTileProperties(i, j, resourceId++, gfx::Rect(0, 0, 1,
1), false); |
| 44 | 52 |
| 45 TEST(TiledLayerImplTest, emptyQuadList) | 53 return layer.Pass(); |
| 54 } |
| 55 |
| 56 void getQuads(QuadList& quads, SharedQuadStateList& sharedStates, gfx::Size
tileSize, const gfx::Size& layerSize, LayerTilingData::BorderTexelOption borderT
exelOption, const gfx::Rect& visibleContentRect) |
| 57 { |
| 58 scoped_ptr<TiledLayerImpl> layer = createLayer(tileSize, layerSize, bord
erTexelOption); |
| 59 layer->drawProperties().visible_content_rect = visibleContentRect; |
| 60 layer->setBounds(layerSize); |
| 61 |
| 62 MockQuadCuller quadCuller(quads, sharedStates); |
| 63 AppendQuadsData data; |
| 64 layer->appendQuads(quadCuller, data); |
| 65 } |
| 66 |
| 67 protected: |
| 68 FakeImplProxy m_proxy; |
| 69 FakeLayerTreeHostImpl m_hostImpl; |
| 70 }; |
| 71 |
| 72 TEST_F(TiledLayerImplTest, emptyQuadList) |
| 46 { | 73 { |
| 47 const gfx::Size tileSize(90, 90); | 74 const gfx::Size tileSize(90, 90); |
| 48 const int numTilesX = 8; | 75 const int numTilesX = 8; |
| 49 const int numTilesY = 4; | 76 const int numTilesY = 4; |
| 50 const gfx::Size layerSize(tileSize.width() * numTilesX, tileSize.height() *
numTilesY); | 77 const gfx::Size layerSize(tileSize.width() * numTilesX, tileSize.height() *
numTilesY); |
| 51 | 78 |
| 52 // Verify default layer does creates quads | 79 // Verify default layer does creates quads |
| 53 { | 80 { |
| 54 scoped_ptr<TiledLayerImpl> layer = createLayer(tileSize, layerSize, Laye
rTilingData::NoBorderTexels); | 81 scoped_ptr<TiledLayerImpl> layer = createLayer(tileSize, layerSize, Laye
rTilingData::NoBorderTexels); |
| 55 MockQuadCuller quadCuller; | 82 MockQuadCuller quadCuller; |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 88 scoped_ptr<TiledLayerImpl> layer = createLayer(tileSize, layerSize, Laye
rTilingData::NoBorderTexels); | 115 scoped_ptr<TiledLayerImpl> layer = createLayer(tileSize, layerSize, Laye
rTilingData::NoBorderTexels); |
| 89 layer->setSkipsDraw(true); | 116 layer->setSkipsDraw(true); |
| 90 | 117 |
| 91 MockQuadCuller quadCuller; | 118 MockQuadCuller quadCuller; |
| 92 AppendQuadsData data; | 119 AppendQuadsData data; |
| 93 layer->appendQuads(quadCuller, data); | 120 layer->appendQuads(quadCuller, data); |
| 94 EXPECT_EQ(quadCuller.quadList().size(), 0u); | 121 EXPECT_EQ(quadCuller.quadList().size(), 0u); |
| 95 } | 122 } |
| 96 } | 123 } |
| 97 | 124 |
| 98 TEST(TiledLayerImplTest, checkerboarding) | 125 TEST_F(TiledLayerImplTest, checkerboarding) |
| 99 { | 126 { |
| 100 const gfx::Size tileSize(10, 10); | 127 const gfx::Size tileSize(10, 10); |
| 101 const int numTilesX = 2; | 128 const int numTilesX = 2; |
| 102 const int numTilesY = 2; | 129 const int numTilesY = 2; |
| 103 const gfx::Size layerSize(tileSize.width() * numTilesX, tileSize.height() *
numTilesY); | 130 const gfx::Size layerSize(tileSize.width() * numTilesX, tileSize.height() *
numTilesY); |
| 104 | 131 |
| 105 scoped_ptr<TiledLayerImpl> layer = createLayer(tileSize, layerSize, LayerTil
ingData::NoBorderTexels); | 132 scoped_ptr<TiledLayerImpl> layer = createLayer(tileSize, layerSize, LayerTil
ingData::NoBorderTexels); |
| 106 | 133 |
| 107 // No checkerboarding | 134 // No checkerboarding |
| 108 { | 135 { |
| (...skipping 16 matching lines...) Expand all Loading... |
| 125 MockQuadCuller quadCuller; | 152 MockQuadCuller quadCuller; |
| 126 AppendQuadsData data; | 153 AppendQuadsData data; |
| 127 layer->appendQuads(quadCuller, data); | 154 layer->appendQuads(quadCuller, data); |
| 128 EXPECT_TRUE(data.hadMissingTiles); | 155 EXPECT_TRUE(data.hadMissingTiles); |
| 129 EXPECT_EQ(quadCuller.quadList().size(), 4u); | 156 EXPECT_EQ(quadCuller.quadList().size(), 4u); |
| 130 for (size_t i = 0; i < quadCuller.quadList().size(); ++i) | 157 for (size_t i = 0; i < quadCuller.quadList().size(); ++i) |
| 131 EXPECT_NE(quadCuller.quadList()[i]->material, DrawQuad::TILED_CONTEN
T); | 158 EXPECT_NE(quadCuller.quadList()[i]->material, DrawQuad::TILED_CONTEN
T); |
| 132 } | 159 } |
| 133 } | 160 } |
| 134 | 161 |
| 135 static void getQuads(QuadList& quads, SharedQuadStateList& sharedStates, gfx::Si
ze tileSize, const gfx::Size& layerSize, LayerTilingData::BorderTexelOption bord
erTexelOption, const gfx::Rect& visibleContentRect) | |
| 136 { | |
| 137 scoped_ptr<TiledLayerImpl> layer = createLayer(tileSize, layerSize, borderTe
xelOption); | |
| 138 layer->drawProperties().visible_content_rect = visibleContentRect; | |
| 139 layer->setBounds(layerSize); | |
| 140 | |
| 141 MockQuadCuller quadCuller(quads, sharedStates); | |
| 142 AppendQuadsData data; | |
| 143 layer->appendQuads(quadCuller, data); | |
| 144 } | |
| 145 | |
| 146 // Test with both border texels and without. | 162 // Test with both border texels and without. |
| 147 #define WITH_AND_WITHOUT_BORDER_TEST(testFixtureName) \ | 163 #define WITH_AND_WITHOUT_BORDER_TEST(testFixtureName) \ |
| 148 TEST(TiledLayerImplTest, testFixtureName##NoBorders) \ | 164 TEST_F(TiledLayerImplBorderTest, testFixtureName##NoBorders) \ |
| 149 { \ | 165 { \ |
| 150 testFixtureName(LayerTilingData::NoBorderTexels); \ | 166 testFixtureName(LayerTilingData::NoBorderTexels); \ |
| 151 } \ | 167 } \ |
| 152 TEST(TiledLayerImplTest, testFixtureName##HasBorders) \ | 168 TEST_F(TiledLayerImplBorderTest, testFixtureName##HasBorders) \ |
| 153 { \ | 169 { \ |
| 154 testFixtureName(LayerTilingData::HasBorderTexels);\ | 170 testFixtureName(LayerTilingData::HasBorderTexels); \ |
| 155 } | 171 } |
| 156 | 172 |
| 157 static void coverageVisibleRectOnTileBoundaries(LayerTilingData::BorderTexelOpti
on borders) | 173 class TiledLayerImplBorderTest : public TiledLayerImplTest |
| 158 { | 174 { |
| 159 gfx::Size layerSize(1000, 1000); | 175 public: |
| 160 QuadList quads; | 176 void coverageVisibleRectOnTileBoundaries(LayerTilingData::BorderTexelOption
borders) |
| 161 SharedQuadStateList sharedStates; | 177 { |
| 162 getQuads(quads, sharedStates, gfx::Size(100, 100), layerSize, borders, gfx::
Rect(gfx::Point(), layerSize)); | 178 gfx::Size layerSize(1000, 1000); |
| 163 verifyQuadsExactlyCoverRect(quads, gfx::Rect(gfx::Point(), layerSize)); | 179 QuadList quads; |
| 164 } | 180 SharedQuadStateList sharedStates; |
| 181 getQuads(quads, sharedStates, gfx::Size(100, 100), layerSize, borders, g
fx::Rect(gfx::Point(), layerSize)); |
| 182 verifyQuadsExactlyCoverRect(quads, gfx::Rect(gfx::Point(), layerSize)); |
| 183 } |
| 184 |
| 185 void coverageVisibleRectIntersectsTiles(LayerTilingData::BorderTexelOption b
orders) |
| 186 { |
| 187 // This rect intersects the middle 3x3 of the 5x5 tiles. |
| 188 gfx::Point topLeft(65, 73); |
| 189 gfx::Point bottomRight(182, 198); |
| 190 gfx::Rect visibleContentRect = gfx::BoundingRect(topLeft, bottomRight); |
| 191 |
| 192 gfx::Size layerSize(250, 250); |
| 193 QuadList quads; |
| 194 SharedQuadStateList sharedStates; |
| 195 getQuads(quads, sharedStates, gfx::Size(50, 50), gfx::Size(250, 250), La
yerTilingData::NoBorderTexels, visibleContentRect); |
| 196 verifyQuadsExactlyCoverRect(quads, visibleContentRect); |
| 197 } |
| 198 |
| 199 void coverageVisibleRectIntersectsBounds(LayerTilingData::BorderTexelOption
borders) |
| 200 { |
| 201 gfx::Size layerSize(220, 210); |
| 202 gfx::Rect visibleContentRect(gfx::Point(), layerSize); |
| 203 QuadList quads; |
| 204 SharedQuadStateList sharedStates; |
| 205 getQuads(quads, sharedStates, gfx::Size(100, 100), layerSize, LayerTilin
gData::NoBorderTexels, visibleContentRect); |
| 206 verifyQuadsExactlyCoverRect(quads, visibleContentRect); |
| 207 } |
| 208 }; |
| 165 WITH_AND_WITHOUT_BORDER_TEST(coverageVisibleRectOnTileBoundaries); | 209 WITH_AND_WITHOUT_BORDER_TEST(coverageVisibleRectOnTileBoundaries); |
| 166 | 210 |
| 167 static void coverageVisibleRectIntersectsTiles(LayerTilingData::BorderTexelOptio
n borders) | |
| 168 { | |
| 169 // This rect intersects the middle 3x3 of the 5x5 tiles. | |
| 170 gfx::Point topLeft(65, 73); | |
| 171 gfx::Point bottomRight(182, 198); | |
| 172 gfx::Rect visibleContentRect = gfx::BoundingRect(topLeft, bottomRight); | |
| 173 | |
| 174 gfx::Size layerSize(250, 250); | |
| 175 QuadList quads; | |
| 176 SharedQuadStateList sharedStates; | |
| 177 getQuads(quads, sharedStates, gfx::Size(50, 50), gfx::Size(250, 250), LayerT
ilingData::NoBorderTexels, visibleContentRect); | |
| 178 verifyQuadsExactlyCoverRect(quads, visibleContentRect); | |
| 179 } | |
| 180 WITH_AND_WITHOUT_BORDER_TEST(coverageVisibleRectIntersectsTiles); | 211 WITH_AND_WITHOUT_BORDER_TEST(coverageVisibleRectIntersectsTiles); |
| 181 | 212 |
| 182 static void coverageVisibleRectIntersectsBounds(LayerTilingData::BorderTexelOpti
on borders) | |
| 183 { | |
| 184 gfx::Size layerSize(220, 210); | |
| 185 gfx::Rect visibleContentRect(gfx::Point(), layerSize); | |
| 186 QuadList quads; | |
| 187 SharedQuadStateList sharedStates; | |
| 188 getQuads(quads, sharedStates, gfx::Size(100, 100), layerSize, LayerTilingDat
a::NoBorderTexels, visibleContentRect); | |
| 189 verifyQuadsExactlyCoverRect(quads, visibleContentRect); | |
| 190 } | |
| 191 WITH_AND_WITHOUT_BORDER_TEST(coverageVisibleRectIntersectsBounds); | 213 WITH_AND_WITHOUT_BORDER_TEST(coverageVisibleRectIntersectsBounds); |
| 192 | 214 |
| 193 TEST(TiledLayerImplTest, textureInfoForLayerNoBorders) | 215 TEST_F(TiledLayerImplTest, textureInfoForLayerNoBorders) |
| 194 { | 216 { |
| 195 gfx::Size tileSize(50, 50); | 217 gfx::Size tileSize(50, 50); |
| 196 gfx::Size layerSize(250, 250); | 218 gfx::Size layerSize(250, 250); |
| 197 QuadList quads; | 219 QuadList quads; |
| 198 SharedQuadStateList sharedStates; | 220 SharedQuadStateList sharedStates; |
| 199 getQuads(quads, sharedStates, tileSize, layerSize, LayerTilingData::NoBorder
Texels, gfx::Rect(gfx::Point(), layerSize)); | 221 getQuads(quads, sharedStates, tileSize, layerSize, LayerTilingData::NoBorder
Texels, gfx::Rect(gfx::Point(), layerSize)); |
| 200 | 222 |
| 201 for (size_t i = 0; i < quads.size(); ++i) { | 223 for (size_t i = 0; i < quads.size(); ++i) { |
| 202 const TileDrawQuad* quad = TileDrawQuad::MaterialCast(quads[i]); | 224 const TileDrawQuad* quad = TileDrawQuad::MaterialCast(quads[i]); |
| 203 | 225 |
| 204 EXPECT_NE(0u, quad->resource_id) << quadString << i; | 226 EXPECT_NE(0u, quad->resource_id) << quadString << i; |
| 205 EXPECT_EQ(gfx::RectF(gfx::PointF(), tileSize), quad->tex_coord_rect) <<
quadString << i; | 227 EXPECT_EQ(gfx::RectF(gfx::PointF(), tileSize), quad->tex_coord_rect) <<
quadString << i; |
| 206 EXPECT_EQ(tileSize, quad->texture_size) << quadString << i; | 228 EXPECT_EQ(tileSize, quad->texture_size) << quadString << i; |
| 207 EXPECT_EQ(gfx::Rect(0, 0, 1, 1), quad->opaque_rect) << quadString << i; | 229 EXPECT_EQ(gfx::Rect(0, 0, 1, 1), quad->opaque_rect) << quadString << i; |
| 208 } | 230 } |
| 209 } | 231 } |
| 210 | 232 |
| 211 } // namespace | 233 } // namespace |
| 212 } // namespace cc | 234 } // namespace cc |
| OLD | NEW |