Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/surface_layer.h" | 5 #include "cc/layers/surface_layer.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include "base/macros.h" | 9 #include "base/macros.h" |
| 10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 56 return make_scoped_refptr(new SurfaceLayer(std::move(ref_factory))); | 56 return make_scoped_refptr(new SurfaceLayer(std::move(ref_factory))); |
| 57 } | 57 } |
| 58 | 58 |
| 59 SurfaceLayer::SurfaceLayer(scoped_refptr<SurfaceReferenceFactory> ref_factory) | 59 SurfaceLayer::SurfaceLayer(scoped_refptr<SurfaceReferenceFactory> ref_factory) |
| 60 : ref_factory_(std::move(ref_factory)) {} | 60 : ref_factory_(std::move(ref_factory)) {} |
| 61 | 61 |
| 62 SurfaceLayer::~SurfaceLayer() { | 62 SurfaceLayer::~SurfaceLayer() { |
| 63 DCHECK(!layer_tree_host()); | 63 DCHECK(!layer_tree_host()); |
| 64 } | 64 } |
| 65 | 65 |
| 66 void SurfaceLayer::AddSurfaceId(const SurfaceInfo& surface_info) { | |
| 67 DCHECK(layer_tree_host()); | |
| 68 if (surface_info.is_valid()) | |
| 69 layer_tree_host()->AddSurfaceLayerId(surface_info.id()); | |
| 70 } | |
| 71 | |
| 72 void SurfaceLayer::RemoveSurfaceId(const SurfaceInfo& surface_info) { | |
| 73 DCHECK(layer_tree_host()); | |
| 74 if (surface_info.is_valid()) | |
| 75 layer_tree_host()->RemoveSurfaceLayerId(surface_info.id()); | |
| 76 } | |
| 77 | |
| 66 void SurfaceLayer::SetPrimarySurfaceInfo(const SurfaceInfo& surface_info) { | 78 void SurfaceLayer::SetPrimarySurfaceInfo(const SurfaceInfo& surface_info) { |
| 67 RemoveReference(std::move(primary_reference_returner_)); | 79 RemoveReference(std::move(primary_reference_returner_)); |
| 80 if (layer_tree_host()) | |
| 81 RemoveSurfaceId(primary_surface_info_); | |
| 68 primary_surface_info_ = surface_info; | 82 primary_surface_info_ = surface_info; |
| 69 if (layer_tree_host()) { | 83 if (layer_tree_host()) { |
| 70 primary_reference_returner_ = ref_factory_->CreateReference( | 84 primary_reference_returner_ = ref_factory_->CreateReference( |
| 71 layer_tree_host(), primary_surface_info_.id()); | 85 layer_tree_host(), primary_surface_info_.id()); |
| 86 AddSurfaceId(primary_surface_info_); | |
| 72 } | 87 } |
| 73 UpdateDrawsContent(HasDrawableContent()); | 88 UpdateDrawsContent(HasDrawableContent()); |
| 74 SetNeedsCommit(); | 89 SetNeedsCommit(); |
| 75 } | 90 } |
| 76 | 91 |
| 77 void SurfaceLayer::SetFallbackSurfaceInfo(const SurfaceInfo& surface_info) { | 92 void SurfaceLayer::SetFallbackSurfaceInfo(const SurfaceInfo& surface_info) { |
| 78 RemoveReference(std::move(fallback_reference_returner_)); | 93 RemoveReference(std::move(fallback_reference_returner_)); |
| 94 if (layer_tree_host()) | |
| 95 RemoveSurfaceId(fallback_surface_info_); | |
| 79 fallback_surface_info_ = surface_info; | 96 fallback_surface_info_ = surface_info; |
| 80 if (layer_tree_host()) { | 97 if (layer_tree_host()) { |
| 81 fallback_reference_returner_ = ref_factory_->CreateReference( | 98 fallback_reference_returner_ = ref_factory_->CreateReference( |
| 82 layer_tree_host(), fallback_surface_info_.id()); | 99 layer_tree_host(), fallback_surface_info_.id()); |
| 100 AddSurfaceId(fallback_surface_info_); | |
| 83 } | 101 } |
| 84 SetNeedsCommit(); | 102 SetNeedsCommit(); |
| 85 } | 103 } |
| 86 | 104 |
| 87 void SurfaceLayer::SetStretchContentToFillBounds( | 105 void SurfaceLayer::SetStretchContentToFillBounds( |
| 88 bool stretch_content_to_fill_bounds) { | 106 bool stretch_content_to_fill_bounds) { |
| 89 stretch_content_to_fill_bounds_ = stretch_content_to_fill_bounds; | 107 stretch_content_to_fill_bounds_ = stretch_content_to_fill_bounds; |
| 90 SetNeedsPushProperties(); | 108 SetNeedsPushProperties(); |
| 91 } | 109 } |
| 92 | 110 |
| 93 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl( | 111 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl( |
| 94 LayerTreeImpl* tree_impl) { | 112 LayerTreeImpl* tree_impl) { |
| 95 return SurfaceLayerImpl::Create(tree_impl, id()); | 113 return SurfaceLayerImpl::Create(tree_impl, id()); |
| 96 } | 114 } |
| 97 | 115 |
| 98 bool SurfaceLayer::HasDrawableContent() const { | 116 bool SurfaceLayer::HasDrawableContent() const { |
| 99 return primary_surface_info_.is_valid() && Layer::HasDrawableContent(); | 117 return primary_surface_info_.is_valid() && Layer::HasDrawableContent(); |
| 100 } | 118 } |
| 101 | 119 |
| 102 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) { | 120 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) { |
| 103 if (layer_tree_host() == host) { | 121 if (layer_tree_host() == host) { |
| 104 Layer::SetLayerTreeHost(host); | 122 Layer::SetLayerTreeHost(host); |
| 105 return; | 123 return; |
| 106 } | 124 } |
| 125 | |
| 126 if (layer_tree_host()) { | |
| 127 RemoveSurfaceId(primary_surface_info_); | |
| 128 RemoveSurfaceId(fallback_surface_info_); | |
|
Fady Samuel
2017/05/24 22:31:14
This breaks surface synchronization and surface re
jaydasika
2017/05/24 22:43:03
I did not understand how removing surface ids from
| |
| 129 } | |
| 107 RemoveReference(std::move(primary_reference_returner_)); | 130 RemoveReference(std::move(primary_reference_returner_)); |
| 108 RemoveReference(std::move(fallback_reference_returner_)); | 131 RemoveReference(std::move(fallback_reference_returner_)); |
| 109 Layer::SetLayerTreeHost(host); | 132 Layer::SetLayerTreeHost(host); |
| 110 if (layer_tree_host()) { | 133 if (layer_tree_host()) { |
| 111 if (primary_surface_info_.is_valid()) { | 134 if (primary_surface_info_.is_valid()) { |
| 112 primary_reference_returner_ = ref_factory_->CreateReference( | 135 primary_reference_returner_ = ref_factory_->CreateReference( |
| 113 layer_tree_host(), primary_surface_info_.id()); | 136 layer_tree_host(), primary_surface_info_.id()); |
| 114 } | 137 } |
| 115 if (fallback_surface_info_.is_valid()) { | 138 if (fallback_surface_info_.is_valid()) { |
| 116 fallback_reference_returner_ = ref_factory_->CreateReference( | 139 fallback_reference_returner_ = ref_factory_->CreateReference( |
| 117 layer_tree_host(), fallback_surface_info_.id()); | 140 layer_tree_host(), fallback_surface_info_.id()); |
| 118 } | 141 } |
| 142 AddSurfaceId(primary_surface_info_); | |
| 143 AddSurfaceId(fallback_surface_info_); | |
| 119 } | 144 } |
| 120 } | 145 } |
| 121 | 146 |
| 122 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) { | 147 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) { |
| 123 Layer::PushPropertiesTo(layer); | 148 Layer::PushPropertiesTo(layer); |
| 124 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo"); | 149 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo"); |
| 125 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer); | 150 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer); |
| 126 layer_impl->SetPrimarySurfaceInfo(primary_surface_info_); | 151 layer_impl->SetPrimarySurfaceInfo(primary_surface_info_); |
| 127 layer_impl->SetFallbackSurfaceInfo(fallback_surface_info_); | 152 layer_impl->SetFallbackSurfaceInfo(fallback_surface_info_); |
| 128 layer_impl->SetStretchContentToFillBounds(stretch_content_to_fill_bounds_); | 153 layer_impl->SetStretchContentToFillBounds(stretch_content_to_fill_bounds_); |
| 129 } | 154 } |
| 130 | 155 |
| 131 void SurfaceLayer::RemoveReference(base::Closure reference_returner) { | 156 void SurfaceLayer::RemoveReference(base::Closure reference_returner) { |
| 132 if (!reference_returner) | 157 if (!reference_returner) |
| 133 return; | 158 return; |
| 134 auto swap_promise = base::MakeUnique<SatisfySwapPromise>( | 159 auto swap_promise = base::MakeUnique<SatisfySwapPromise>( |
| 135 std::move(reference_returner), | 160 std::move(reference_returner), |
| 136 layer_tree_host()->GetTaskRunnerProvider()->MainThreadTaskRunner()); | 161 layer_tree_host()->GetTaskRunnerProvider()->MainThreadTaskRunner()); |
| 137 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise( | 162 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise( |
| 138 std::move(swap_promise)); | 163 std::move(swap_promise)); |
| 139 } | 164 } |
| 140 | 165 |
| 141 } // namespace cc | 166 } // namespace cc |
| OLD | NEW |