diff options
author | enne@chromium.org <enne@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-11-21 19:15:27 +0000 |
---|---|---|
committer | enne@chromium.org <enne@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-11-21 19:15:27 +0000 |
commit | cd696271b3c491f2de0109e4dc6d991884f89540 (patch) | |
tree | 9425a004275595dd0d354b730cf47d58e24d6b93 /cc/picture_layer_tiling_set_unittest.cc | |
parent | 6c99c7bc949fc15b559793467fc1e1a6df857372 (diff) | |
download | chromium_src-cd696271b3c491f2de0109e4dc6d991884f89540.zip chromium_src-cd696271b3c491f2de0109e4dc6d991884f89540.tar.gz chromium_src-cd696271b3c491f2de0109e4dc6d991884f89540.tar.bz2 |
cc: Add PictureLayerTilingSet to manage PictureLayerTiling
PictureLayerTilingSet has multiple tilings at different content scales.
This should abstract managing the tilings from PictureLayerImpl. The
layer can then ask the set to fill in a given (integer) rect at a given
content scale and then get back the set of tiles/rects/texture
coordinates to generate that set. Using an integer rect allows textures
at different contents scales to fill a piece of geometry without cracks.
R=nduca@chromium.org
BUG=155209
Review URL: https://chromiumcodereview.appspot.com/11417111
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@169083 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'cc/picture_layer_tiling_set_unittest.cc')
-rw-r--r-- | cc/picture_layer_tiling_set_unittest.cc | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/cc/picture_layer_tiling_set_unittest.cc b/cc/picture_layer_tiling_set_unittest.cc new file mode 100644 index 0000000..8b0aa72 --- /dev/null +++ b/cc/picture_layer_tiling_set_unittest.cc @@ -0,0 +1,44 @@ +// Copyright 2012 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "cc/picture_layer_tiling_set.h" + +#include "cc/test/fake_picture_layer_tiling_client.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "ui/gfx/size_conversions.h" + +namespace cc { + +TEST(PictureLayerTilingSetTest, NoResources) { + FakePictureLayerTilingClient client; + PictureLayerTilingSet set(&client); + gfx::Size default_tile_size(256, 256); + + gfx::Size layer_bounds(1000, 800); + set.SetLayerBounds(layer_bounds); + + set.AddTiling(1.0, default_tile_size); + set.AddTiling(1.5, default_tile_size); + set.AddTiling(2.0, default_tile_size); + + float contents_scale = 2.0; + gfx::Size content_bounds( + gfx::ToCeiledSize(gfx::ScaleSize(layer_bounds, contents_scale))); + gfx::Rect content_rect(gfx::Point(), content_bounds); + + Region remaining(content_rect); + PictureLayerTilingSet::Iterator iter(&set, contents_scale, content_rect); + for (; iter; ++iter) { + gfx::Rect geometry_rect = iter.geometry_rect(); + EXPECT_TRUE(content_rect.Contains(geometry_rect)); + ASSERT_TRUE(remaining.Contains(geometry_rect)); + remaining.Subtract(geometry_rect); + + // No tiles have resources, so no iter represents a real tile. + EXPECT_FALSE(*iter); + } + EXPECT_TRUE(remaining.IsEmpty()); +} + +} // namespace cc |