Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(38)

Side by Side Diff: cc/layers/layer_impl.cc

Issue 1944623002: CC Animation: Use ElementId to attach CC animation players. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@erasedomids
Patch Set: Let CC clients generate their own ElementIds locally. Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/layer_impl.h" 5 #include "cc/layers/layer_impl.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <algorithm> 10 #include <algorithm>
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after
81 current_draw_mode_(DRAW_MODE_NONE), 81 current_draw_mode_(DRAW_MODE_NONE),
82 element_id_(0), 82 element_id_(0),
83 mutable_properties_(MutableProperty::kNone), 83 mutable_properties_(MutableProperty::kNone),
84 debug_info_(nullptr), 84 debug_info_(nullptr),
85 scrolls_drawn_descendant_(false), 85 scrolls_drawn_descendant_(false),
86 layer_or_descendant_has_touch_handler_(false) { 86 layer_or_descendant_has_touch_handler_(false) {
87 DCHECK_GT(layer_id_, 0); 87 DCHECK_GT(layer_id_, 0);
88 88
89 DCHECK(layer_tree_impl_); 89 DCHECK(layer_tree_impl_);
90 layer_tree_impl_->RegisterLayer(this); 90 layer_tree_impl_->RegisterLayer(this);
91 // TODO(loyso): Pass element_id_ via constructor.
92 // Note that since element_id_ is zero here, calling RegisterLayerForElementId
93 // and AddToElementMap is a matter of elegance/symmetry. See SetElementId.
94 if (element_id())
95 layer_tree_impl_->RegisterLayerForElementId(this);
91 layer_tree_impl_->AddToElementMap(this); 96 layer_tree_impl_->AddToElementMap(this);
92 97
93 SetNeedsPushProperties(); 98 SetNeedsPushProperties();
94 } 99 }
95 100
96 LayerImpl::~LayerImpl() { 101 LayerImpl::~LayerImpl() {
97 DCHECK_EQ(DRAW_MODE_NONE, current_draw_mode_); 102 DCHECK_EQ(DRAW_MODE_NONE, current_draw_mode_);
98 103
99 if (!copy_requests_.empty() && layer_tree_impl_->IsActiveTree()) 104 if (!copy_requests_.empty() && layer_tree_impl_->IsActiveTree())
100 layer_tree_impl()->RemoveLayerWithCopyOutputRequest(this); 105 layer_tree_impl()->RemoveLayerWithCopyOutputRequest(this);
101 layer_tree_impl_->UnregisterScrollLayer(this); 106 layer_tree_impl_->UnregisterScrollLayer(this);
102 layer_tree_impl_->UnregisterLayer(this);
103 layer_tree_impl_->RemoveLayerShouldPushProperties(this);
104 107
105 layer_tree_impl_->RemoveFromElementMap(this); 108 layer_tree_impl_->RemoveFromElementMap(this);
109 if (element_id())
110 layer_tree_impl_->UnregisterLayerForElementId(this);
111 layer_tree_impl_->UnregisterLayer(this);
112
113 layer_tree_impl_->RemoveLayerShouldPushProperties(this);
106 114
107 TRACE_EVENT_OBJECT_DELETED_WITH_ID( 115 TRACE_EVENT_OBJECT_DELETED_WITH_ID(
108 TRACE_DISABLED_BY_DEFAULT("cc.debug"), "cc::LayerImpl", this); 116 TRACE_DISABLED_BY_DEFAULT("cc.debug"), "cc::LayerImpl", this);
109 117
110 if (mask_layer_) 118 if (mask_layer_)
111 layer_tree_impl_->RemoveLayer(mask_layer_id_); 119 layer_tree_impl_->RemoveLayer(mask_layer_id_);
112 if (replica_layer_) 120 if (replica_layer_)
113 layer_tree_impl_->RemoveLayer(replica_layer_id_); 121 layer_tree_impl_->RemoveLayer(replica_layer_id_);
114 ClearChildList(); 122 ClearChildList();
115 } 123 }
(...skipping 265 matching lines...) Expand 10 before | Expand all | Expand 10 after
381 ScrollTree& scroll_tree = layer_tree_impl()->property_trees()->scroll_tree; 389 ScrollTree& scroll_tree = layer_tree_impl()->property_trees()->scroll_tree;
382 ScrollNode* scroll_node = scroll_tree.Node(scroll_tree_index()); 390 ScrollNode* scroll_node = scroll_tree.Node(scroll_tree_index());
383 return scroll_tree.ScrollBy(scroll_node, scroll, layer_tree_impl()); 391 return scroll_tree.ScrollBy(scroll_node, scroll, layer_tree_impl());
384 } 392 }
385 393
386 void LayerImpl::SetScrollClipLayer(int scroll_clip_layer_id) { 394 void LayerImpl::SetScrollClipLayer(int scroll_clip_layer_id) {
387 if (scroll_clip_layer_id_ == scroll_clip_layer_id) 395 if (scroll_clip_layer_id_ == scroll_clip_layer_id)
388 return; 396 return;
389 397
390 layer_tree_impl()->UnregisterScrollLayer(this); 398 layer_tree_impl()->UnregisterScrollLayer(this);
399 if (element_id())
400 layer_tree_impl()->UnregisterLayerForElementId(this);
401
391 scroll_clip_layer_id_ = scroll_clip_layer_id; 402 scroll_clip_layer_id_ = scroll_clip_layer_id;
403
404 if (element_id())
405 layer_tree_impl()->RegisterLayerForElementId(this);
392 layer_tree_impl()->RegisterScrollLayer(this); 406 layer_tree_impl()->RegisterScrollLayer(this);
393 } 407 }
394 408
395 LayerImpl* LayerImpl::scroll_clip_layer() const { 409 LayerImpl* LayerImpl::scroll_clip_layer() const {
396 return layer_tree_impl()->LayerById(scroll_clip_layer_id_); 410 return layer_tree_impl()->LayerById(scroll_clip_layer_id_);
397 } 411 }
398 412
399 bool LayerImpl::scrollable() const { 413 bool LayerImpl::scrollable() const {
400 return scroll_clip_layer_id_ != Layer::INVALID_ID; 414 return scroll_clip_layer_id_ != Layer::INVALID_ID;
401 } 415 }
(...skipping 596 matching lines...) Expand 10 before | Expand all | Expand 10 after
998 } 1012 }
999 1013
1000 void LayerImpl::SetElementId(ElementId element_id) { 1014 void LayerImpl::SetElementId(ElementId element_id) {
1001 if (element_id == element_id_) 1015 if (element_id == element_id_)
1002 return; 1016 return;
1003 1017
1004 TRACE_EVENT1(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), 1018 TRACE_EVENT1(TRACE_DISABLED_BY_DEFAULT("compositor-worker"),
1005 "LayerImpl::SetElementId", "id", element_id); 1019 "LayerImpl::SetElementId", "id", element_id);
1006 1020
1007 layer_tree_impl_->RemoveFromElementMap(this); 1021 layer_tree_impl_->RemoveFromElementMap(this);
1022 if (element_id_)
1023 layer_tree_impl_->UnregisterLayerForElementId(this);
1024
1008 element_id_ = element_id; 1025 element_id_ = element_id;
1026
1009 layer_tree_impl_->AddToElementMap(this); 1027 layer_tree_impl_->AddToElementMap(this);
1028 if (element_id_)
1029 layer_tree_impl_->RegisterLayerForElementId(this);
1030
1010 SetNeedsPushProperties(); 1031 SetNeedsPushProperties();
1011 } 1032 }
1012 1033
1013 void LayerImpl::SetMutableProperties(uint32_t properties) { 1034 void LayerImpl::SetMutableProperties(uint32_t properties) {
1014 if (mutable_properties_ == properties) 1035 if (mutable_properties_ == properties)
1015 return; 1036 return;
1016 1037
1017 TRACE_EVENT1(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), 1038 TRACE_EVENT1(TRACE_DISABLED_BY_DEFAULT("compositor-worker"),
1018 "LayerImpl::SetMutableProperties", "properties", properties); 1039 "LayerImpl::SetMutableProperties", "properties", properties);
1019 1040
(...skipping 372 matching lines...) Expand 10 before | Expand all | Expand 10 after
1392 .layer_transforms_should_scale_layer_contents) { 1413 .layer_transforms_should_scale_layer_contents) {
1393 return default_scale; 1414 return default_scale;
1394 } 1415 }
1395 1416
1396 gfx::Vector2dF transform_scales = MathUtil::ComputeTransform2dScaleComponents( 1417 gfx::Vector2dF transform_scales = MathUtil::ComputeTransform2dScaleComponents(
1397 DrawTransform(), default_scale); 1418 DrawTransform(), default_scale);
1398 return std::max(transform_scales.x(), transform_scales.y()); 1419 return std::max(transform_scales.x(), transform_scales.y());
1399 } 1420 }
1400 1421
1401 } // namespace cc 1422 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698