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 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 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::SetPrimarySurfaceInfo(const SurfaceInfo& surface_info) { | 66 void SurfaceLayer::SetPrimarySurfaceInfo(const SurfaceInfo& surface_info) { | 
| 67 const SurfaceId* old_surface_id = GetReferencedSurfaceId(); | |
| 67 RemoveReference(std::move(primary_reference_returner_)); | 68 RemoveReference(std::move(primary_reference_returner_)); | 
| 68 primary_surface_info_ = surface_info; | 69 primary_surface_info_ = surface_info; | 
| 69 if (layer_tree_host()) { | 70 if (layer_tree_host()) { | 
| 70 primary_reference_returner_ = ref_factory_->CreateReference( | 71 primary_reference_returner_ = ref_factory_->CreateReference( | 
| 71 layer_tree_host(), primary_surface_info_.id()); | 72 layer_tree_host(), primary_surface_info_.id()); | 
| 73 const SurfaceId* new_surface_id = GetReferencedSurfaceId(); | |
| 74 if (old_surface_id != new_surface_id) { | |
| 75 if (old_surface_id) | |
| 76 layer_tree_host()->RemoveSurfaceLayerId(*old_surface_id); | |
| 77 if (new_surface_id) | |
| 78 layer_tree_host()->AddSurfaceLayerId(*new_surface_id); | |
| 79 } | |
| 72 } | 80 } | 
| 73 UpdateDrawsContent(HasDrawableContent()); | 81 UpdateDrawsContent(HasDrawableContent()); | 
| 74 SetNeedsCommit(); | 82 SetNeedsCommit(); | 
| 75 } | 83 } | 
| 76 | 84 | 
| 77 void SurfaceLayer::SetFallbackSurfaceInfo(const SurfaceInfo& surface_info) { | 85 void SurfaceLayer::SetFallbackSurfaceInfo(const SurfaceInfo& surface_info) { | 
| 86 const SurfaceId* old_surface_id = GetReferencedSurfaceId(); | |
| 78 RemoveReference(std::move(fallback_reference_returner_)); | 87 RemoveReference(std::move(fallback_reference_returner_)); | 
| 79 fallback_surface_info_ = surface_info; | 88 fallback_surface_info_ = surface_info; | 
| 80 if (layer_tree_host()) { | 89 if (layer_tree_host()) { | 
| 81 fallback_reference_returner_ = ref_factory_->CreateReference( | 90 fallback_reference_returner_ = ref_factory_->CreateReference( | 
| 82 layer_tree_host(), fallback_surface_info_.id()); | 91 layer_tree_host(), fallback_surface_info_.id()); | 
| 92 const SurfaceId* new_surface_id = GetReferencedSurfaceId(); | |
| 93 if (old_surface_id != new_surface_id) { | |
| 94 if (old_surface_id) | |
| 95 layer_tree_host()->RemoveSurfaceLayerId(*old_surface_id); | |
| 96 if (new_surface_id) | |
| 97 layer_tree_host()->AddSurfaceLayerId(*new_surface_id); | |
| 98 } | |
| 83 } | 99 } | 
| 84 SetNeedsCommit(); | 100 SetNeedsCommit(); | 
| 85 } | 101 } | 
| 86 | 102 | 
| 87 void SurfaceLayer::SetStretchContentToFillBounds( | 103 void SurfaceLayer::SetStretchContentToFillBounds( | 
| 88 bool stretch_content_to_fill_bounds) { | 104 bool stretch_content_to_fill_bounds) { | 
| 89 stretch_content_to_fill_bounds_ = stretch_content_to_fill_bounds; | 105 stretch_content_to_fill_bounds_ = stretch_content_to_fill_bounds; | 
| 90 SetNeedsPushProperties(); | 106 SetNeedsPushProperties(); | 
| 91 } | 107 } | 
| 92 | 108 | 
| 93 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl( | 109 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl( | 
| 94 LayerTreeImpl* tree_impl) { | 110 LayerTreeImpl* tree_impl) { | 
| 95 return SurfaceLayerImpl::Create(tree_impl, id()); | 111 return SurfaceLayerImpl::Create(tree_impl, id()); | 
| 96 } | 112 } | 
| 97 | 113 | 
| 98 bool SurfaceLayer::HasDrawableContent() const { | 114 bool SurfaceLayer::HasDrawableContent() const { | 
| 99 return primary_surface_info_.is_valid() && Layer::HasDrawableContent(); | 115 return primary_surface_info_.is_valid() && Layer::HasDrawableContent(); | 
| 100 } | 116 } | 
| 101 | 117 | 
| 118 const SurfaceId* SurfaceLayer::GetReferencedSurfaceId(LayerTreeHost* new_host) { | |
| 
 
enne (OOO)
2017/05/24 18:44:54
This is a lot of logic in SurfaceLayer to try to a
 
jaydasika
2017/05/24 21:39:54
Done (sending all primary and fallback surface ids
 
Fady Samuel
2017/05/24 22:46:24
I meant to reply here:
 
jaydasika
2017/05/25 18:00:28
Ok. I have changed the CL again to record only one
 
 | |
| 119 LayerTreeHost* old_host = layer_tree_host(); | |
| 120 if (!old_host && !new_host) | |
| 121 return nullptr; | |
| 122 DCHECK(!old_host || !new_host || | |
| 123 old_host->GetSettings().enable_surface_synchronization == | |
| 124 old_host->GetSettings().enable_surface_synchronization); | |
| 125 | |
| 126 bool enable_surface_synchronization; | |
| 127 if (old_host) { | |
| 128 enable_surface_synchronization = | |
| 129 old_host->GetSettings().enable_surface_synchronization; | |
| 130 } else { | |
| 131 enable_surface_synchronization = | |
| 132 new_host->GetSettings().enable_surface_synchronization; | |
| 133 } | |
| 134 | |
| 135 if (enable_surface_synchronization) { | |
| 136 if (fallback_surface_info_.is_valid()) | |
| 137 return &fallback_surface_info_.id(); | |
| 138 } else if (primary_surface_info_.is_valid()) { | |
| 139 return &primary_surface_info_.id(); | |
| 140 } | |
| 141 return nullptr; | |
| 142 } | |
| 143 | |
| 102 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) { | 144 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) { | 
| 103 if (layer_tree_host() == host) { | 145 if (layer_tree_host() == host) { | 
| 104 Layer::SetLayerTreeHost(host); | 146 Layer::SetLayerTreeHost(host); | 
| 105 return; | 147 return; | 
| 106 } | 148 } | 
| 149 const SurfaceId* surface_id = GetReferencedSurfaceId(host); | |
| 150 | |
| 151 if (layer_tree_host() && surface_id) | |
| 152 layer_tree_host()->RemoveSurfaceLayerId(*surface_id); | |
| 107 RemoveReference(std::move(primary_reference_returner_)); | 153 RemoveReference(std::move(primary_reference_returner_)); | 
| 108 RemoveReference(std::move(fallback_reference_returner_)); | 154 RemoveReference(std::move(fallback_reference_returner_)); | 
| 109 Layer::SetLayerTreeHost(host); | 155 Layer::SetLayerTreeHost(host); | 
| 110 if (layer_tree_host()) { | 156 if (layer_tree_host()) { | 
| 111 if (primary_surface_info_.is_valid()) { | 157 if (primary_surface_info_.is_valid()) { | 
| 112 primary_reference_returner_ = ref_factory_->CreateReference( | 158 primary_reference_returner_ = ref_factory_->CreateReference( | 
| 113 layer_tree_host(), primary_surface_info_.id()); | 159 layer_tree_host(), primary_surface_info_.id()); | 
| 114 } | 160 } | 
| 115 if (fallback_surface_info_.is_valid()) { | 161 if (fallback_surface_info_.is_valid()) { | 
| 116 fallback_reference_returner_ = ref_factory_->CreateReference( | 162 fallback_reference_returner_ = ref_factory_->CreateReference( | 
| 117 layer_tree_host(), fallback_surface_info_.id()); | 163 layer_tree_host(), fallback_surface_info_.id()); | 
| 118 } | 164 } | 
| 165 if (surface_id) | |
| 166 layer_tree_host()->AddSurfaceLayerId(*surface_id); | |
| 119 } | 167 } | 
| 120 } | 168 } | 
| 121 | 169 | 
| 122 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) { | 170 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) { | 
| 123 Layer::PushPropertiesTo(layer); | 171 Layer::PushPropertiesTo(layer); | 
| 124 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo"); | 172 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo"); | 
| 125 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer); | 173 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer); | 
| 126 layer_impl->SetPrimarySurfaceInfo(primary_surface_info_); | 174 layer_impl->SetPrimarySurfaceInfo(primary_surface_info_); | 
| 127 layer_impl->SetFallbackSurfaceInfo(fallback_surface_info_); | 175 layer_impl->SetFallbackSurfaceInfo(fallback_surface_info_); | 
| 128 layer_impl->SetStretchContentToFillBounds(stretch_content_to_fill_bounds_); | 176 layer_impl->SetStretchContentToFillBounds(stretch_content_to_fill_bounds_); | 
| 129 } | 177 } | 
| 130 | 178 | 
| 131 void SurfaceLayer::RemoveReference(base::Closure reference_returner) { | 179 void SurfaceLayer::RemoveReference(base::Closure reference_returner) { | 
| 132 if (!reference_returner) | 180 if (!reference_returner) | 
| 133 return; | 181 return; | 
| 134 auto swap_promise = base::MakeUnique<SatisfySwapPromise>( | 182 auto swap_promise = base::MakeUnique<SatisfySwapPromise>( | 
| 135 std::move(reference_returner), | 183 std::move(reference_returner), | 
| 136 layer_tree_host()->GetTaskRunnerProvider()->MainThreadTaskRunner()); | 184 layer_tree_host()->GetTaskRunnerProvider()->MainThreadTaskRunner()); | 
| 137 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise( | 185 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise( | 
| 138 std::move(swap_promise)); | 186 std::move(swap_promise)); | 
| 139 } | 187 } | 
| 140 | 188 | 
| 141 } // namespace cc | 189 } // namespace cc | 
| OLD | NEW |