| 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/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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 |
| OLD | NEW |