| Index: cc/test/layer_tree_json_parser.cc
|
| diff --git a/cc/test/layer_tree_json_parser.cc b/cc/test/layer_tree_json_parser.cc
|
| deleted file mode 100644
|
| index b0b81f7e803fe3260300d79ae4263c6418b54619..0000000000000000000000000000000000000000
|
| --- a/cc/test/layer_tree_json_parser.cc
|
| +++ /dev/null
|
| @@ -1,198 +0,0 @@
|
| -// Copyright 2013 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/test/layer_tree_json_parser.h"
|
| -
|
| -#include "base/test/values_test_util.h"
|
| -#include "base/values.h"
|
| -#include "cc/layers/content_layer.h"
|
| -#include "cc/layers/layer.h"
|
| -#include "cc/layers/nine_patch_layer.h"
|
| -#include "cc/layers/picture_layer.h"
|
| -#include "cc/layers/solid_color_layer.h"
|
| -#include "cc/layers/texture_layer.h"
|
| -
|
| -namespace cc {
|
| -
|
| -namespace {
|
| -
|
| -scoped_refptr<Layer> ParseTreeFromValue(base::Value* val,
|
| - ContentLayerClient* content_client) {
|
| - base::DictionaryValue* dict;
|
| - bool success = true;
|
| - success &= val->GetAsDictionary(&dict);
|
| - std::string layer_type;
|
| - success &= dict->GetString("LayerType", &layer_type);
|
| - base::ListValue* list;
|
| - success &= dict->GetList("Bounds", &list);
|
| - int width, height;
|
| - success &= list->GetInteger(0, &width);
|
| - success &= list->GetInteger(1, &height);
|
| - success &= dict->GetList("Position", &list);
|
| - double position_x, position_y;
|
| - success &= list->GetDouble(0, &position_x);
|
| - success &= list->GetDouble(1, &position_y);
|
| -
|
| - bool draws_content;
|
| - success &= dict->GetBoolean("DrawsContent", &draws_content);
|
| -
|
| - scoped_refptr<Layer> new_layer;
|
| - if (layer_type == "SolidColorLayer") {
|
| - new_layer = SolidColorLayer::Create();
|
| - } else if (layer_type == "ContentLayer") {
|
| - new_layer = ContentLayer::Create(content_client);
|
| - } else if (layer_type == "NinePatchLayer") {
|
| - success &= dict->GetList("ImageAperture", &list);
|
| - int aperture_x, aperture_y, aperture_width, aperture_height;
|
| - success &= list->GetInteger(0, &aperture_x);
|
| - success &= list->GetInteger(1, &aperture_y);
|
| - success &= list->GetInteger(2, &aperture_width);
|
| - success &= list->GetInteger(3, &aperture_height);
|
| -
|
| - base::ListValue* bounds;
|
| - success &= dict->GetList("ImageBounds", &bounds);
|
| - double image_width, image_height;
|
| - success &= bounds->GetDouble(0, &image_width);
|
| - success &= bounds->GetDouble(1, &image_height);
|
| -
|
| - success &= dict->GetList("Border", &list);
|
| - int border_x, border_y, border_width, border_height;
|
| - success &= list->GetInteger(0, &border_x);
|
| - success &= list->GetInteger(1, &border_y);
|
| - success &= list->GetInteger(2, &border_width);
|
| - success &= list->GetInteger(3, &border_height);
|
| -
|
| - bool fill_center;
|
| - success &= dict->GetBoolean("FillCenter", &fill_center);
|
| -
|
| - scoped_refptr<NinePatchLayer> nine_patch_layer = NinePatchLayer::Create();
|
| -
|
| - SkBitmap bitmap;
|
| - bitmap.allocN32Pixels(image_width, image_height);
|
| - bitmap.setImmutable();
|
| - nine_patch_layer->SetBitmap(bitmap);
|
| - nine_patch_layer->SetAperture(
|
| - gfx::Rect(aperture_x, aperture_y, aperture_width, aperture_height));
|
| - nine_patch_layer->SetBorder(
|
| - gfx::Rect(border_x, border_y, border_width, border_height));
|
| - nine_patch_layer->SetFillCenter(fill_center);
|
| -
|
| - new_layer = nine_patch_layer;
|
| - } else if (layer_type == "TextureLayer") {
|
| - new_layer = TextureLayer::CreateForMailbox(NULL);
|
| - } else if (layer_type == "PictureLayer") {
|
| - new_layer = PictureLayer::Create(content_client);
|
| - } else { // Type "Layer" or "unknown"
|
| - new_layer = Layer::Create();
|
| - }
|
| - new_layer->SetPosition(gfx::PointF(position_x, position_y));
|
| - new_layer->SetBounds(gfx::Size(width, height));
|
| - new_layer->SetIsDrawable(draws_content);
|
| -
|
| - double opacity;
|
| - if (dict->GetDouble("Opacity", &opacity))
|
| - new_layer->SetOpacity(opacity);
|
| -
|
| - bool contents_opaque;
|
| - if (dict->GetBoolean("ContentsOpaque", &contents_opaque))
|
| - new_layer->SetContentsOpaque(contents_opaque);
|
| -
|
| - bool scrollable;
|
| - // TODO(wjmaclean) At some time in the future we may wish to test that a
|
| - // reconstructed layer tree contains the correct linkage for the scroll
|
| - // clip layer. This is complicated by the fact that the json output doesn't
|
| - // (currently) re-construct the tree with the same layer IDs as the original.
|
| - // But, since a clip layer is always an ancestor of the scrollable layer, we
|
| - // can just count the number of upwards hops to the clip layer and write that
|
| - // into the json file (with 0 hops implying no clip layer, i.e. not
|
| - // scrollable). Reconstructing the tree can then be accomplished by passing
|
| - // the parent pointer to this function and traversing the same number of
|
| - // ancestors to determine the pointer to the clip layer. The LayerTreesMatch()
|
| - // function should then check that both original and reconstructed layers
|
| - // have the same positioning with respect to their clip layers.
|
| - //
|
| - // For now, we can safely indicate a layer is scrollable by giving it a
|
| - // pointer to itself, something not normally allowed in a working tree.
|
| - //
|
| - // https://code.google.com/p/chromium/issues/detail?id=330622
|
| - //
|
| - if (dict->GetBoolean("Scrollable", &scrollable))
|
| - new_layer->SetScrollClipLayerId(scrollable ? new_layer->id()
|
| - : Layer::INVALID_ID);
|
| -
|
| - bool wheel_handler;
|
| - if (dict->GetBoolean("WheelHandler", &wheel_handler))
|
| - new_layer->SetHaveWheelEventHandlers(wheel_handler);
|
| -
|
| - bool scroll_handler;
|
| - if (dict->GetBoolean("ScrollHandler", &scroll_handler))
|
| - new_layer->SetHaveScrollEventHandlers(scroll_handler);
|
| -
|
| - bool is_3d_sorted;
|
| - if (dict->GetBoolean("Is3DSorted", &is_3d_sorted)) {
|
| - // A non-zero context ID will put the layer into a 3D sorting context
|
| - new_layer->Set3dSortingContextId(is_3d_sorted ? 1 : 0);
|
| - }
|
| -
|
| - if (dict->HasKey("TouchRegion")) {
|
| - success &= dict->GetList("TouchRegion", &list);
|
| - Region touch_region;
|
| - for (size_t i = 0; i < list->GetSize(); ) {
|
| - int rect_x, rect_y, rect_width, rect_height;
|
| - success &= list->GetInteger(i++, &rect_x);
|
| - success &= list->GetInteger(i++, &rect_y);
|
| - success &= list->GetInteger(i++, &rect_width);
|
| - success &= list->GetInteger(i++, &rect_height);
|
| - touch_region.Union(gfx::Rect(rect_x, rect_y, rect_width, rect_height));
|
| - }
|
| - new_layer->SetTouchEventHandlerRegion(touch_region);
|
| - }
|
| -
|
| - if (dict->HasKey("ScrollBlocksOn")) {
|
| - success &= dict->GetList("ScrollBlocksOn", &list);
|
| - ScrollBlocksOn blocks;
|
| - std::string str;
|
| - for (size_t i = 0; i < list->GetSize(); i++) {
|
| - success &= list->GetString(i, &str);
|
| - if (str == "StartTouch")
|
| - blocks |= SCROLL_BLOCKS_ON_START_TOUCH;
|
| - else if (str == "WheelEvent")
|
| - blocks |= SCROLL_BLOCKS_ON_WHEEL_EVENT;
|
| - else if (str == "ScrollEvent")
|
| - blocks |= SCROLL_BLOCKS_ON_SCROLL_EVENT;
|
| - else
|
| - success = false;
|
| - }
|
| - }
|
| -
|
| - success &= dict->GetList("DrawTransform", &list);
|
| - double transform[16];
|
| - for (int i = 0; i < 16; ++i)
|
| - success &= list->GetDouble(i, &transform[i]);
|
| -
|
| - gfx::Transform layer_transform;
|
| - layer_transform.matrix().setColMajord(transform);
|
| - new_layer->SetTransform(layer_transform);
|
| -
|
| - success &= dict->GetList("Children", &list);
|
| - for (base::ListValue::const_iterator it = list->begin();
|
| - it != list->end(); ++it) {
|
| - new_layer->AddChild(ParseTreeFromValue(*it, content_client));
|
| - }
|
| -
|
| - if (!success)
|
| - return NULL;
|
| -
|
| - return new_layer;
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -scoped_refptr<Layer> ParseTreeFromJson(std::string json,
|
| - ContentLayerClient* content_client) {
|
| - scoped_ptr<base::Value> val = base::test::ParseJson(json);
|
| - return ParseTreeFromValue(val.get(), content_client);
|
| -}
|
| -
|
| -} // namespace cc
|
|
|