| Index: cc/layers/layer.cc
|
| diff --git a/cc/layers/layer.cc b/cc/layers/layer.cc
|
| index 08f39b9a21d6d67805fef6150237b57f3c51f810..7cf0e0fb915611828513d155de71350f70b70e3f 100644
|
| --- a/cc/layers/layer.cc
|
| +++ b/cc/layers/layer.cc
|
| @@ -49,6 +49,9 @@ Layer::Layer()
|
| layer_tree_host_(nullptr),
|
| scroll_clip_layer_id_(INVALID_ID),
|
| num_descendants_that_draw_content_(0),
|
| + transform_tree_index_(-1),
|
| + opacity_tree_index_(-1),
|
| + clip_tree_index_(-1),
|
| should_scroll_on_main_thread_(false),
|
| have_wheel_event_handlers_(false),
|
| have_scroll_event_handlers_(false),
|
| @@ -1233,6 +1236,10 @@ void Layer::AddDrawableDescendants(int num) {
|
| parent()->AddDrawableDescendants(num);
|
| }
|
|
|
| +bool Layer::NeedsVisibleRectUpdated() const {
|
| + return DrawsContent();
|
| +}
|
| +
|
| void Layer::RunMicroBenchmark(MicroBenchmark* benchmark) {
|
| benchmark->RunOnLayer(this);
|
| }
|
| @@ -1241,4 +1248,32 @@ bool Layer::HasDelegatedContent() const {
|
| return false;
|
| }
|
|
|
| +gfx::Transform Layer::debug_screen_space_transform(
|
| + const TransformTree& tree) const {
|
| + gfx::Transform xform(1, 0, 0, 1, offset_to_transform_parent().x(),
|
| + offset_to_transform_parent().y());
|
| + if (transform_tree_index() >= 0) {
|
| + gfx::Transform ssxform = tree.Node(transform_tree_index())->data.to_screen;
|
| + xform.ConcatTransform(ssxform);
|
| + }
|
| + xform.Scale(1.0 / contents_scale_x(), 1.0 / contents_scale_y());
|
| + return xform;
|
| +}
|
| +
|
| +gfx::Transform Layer::debug_draw_transform(const TransformTree& tree) const {
|
| + if (!has_render_target())
|
| + return debug_screen_space_transform(tree);
|
| +
|
| + gfx::Transform xform(1, 0, 0, 1, offset_to_transform_parent().x(),
|
| + offset_to_transform_parent().y());
|
| + if (transform_tree_index() >= 0) {
|
| + gfx::Transform ssxform;
|
| + ComputeTransform(tree, transform_tree_index(),
|
| + render_target()->transform_tree_index(), &ssxform);
|
| + xform.ConcatTransform(ssxform);
|
| + }
|
| + xform.Scale(1.0 / contents_scale_x(), 1.0 / contents_scale_y());
|
| + return xform;
|
| +}
|
| +
|
| } // namespace cc
|
|
|