| OLD | NEW |
| 1 // Copyright 2011 The Chromium Authors. All rights reserved. | 1 // Copyright 2011 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/trees/layer_tree_host.h" | 5 #include "cc/trees/layer_tree_host.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <stack> | 8 #include <stack> |
| 9 | 9 |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| (...skipping 417 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 428 return host_impl.Pass(); | 428 return host_impl.Pass(); |
| 429 } | 429 } |
| 430 | 430 |
| 431 void LayerTreeHost::DidLoseOutputSurface() { | 431 void LayerTreeHost::DidLoseOutputSurface() { |
| 432 TRACE_EVENT0("cc", "LayerTreeHost::DidLoseOutputSurface"); | 432 TRACE_EVENT0("cc", "LayerTreeHost::DidLoseOutputSurface"); |
| 433 DCHECK(proxy_->IsMainThread()); | 433 DCHECK(proxy_->IsMainThread()); |
| 434 | 434 |
| 435 if (output_surface_lost_) | 435 if (output_surface_lost_) |
| 436 return; | 436 return; |
| 437 | 437 |
| 438 DidLoseUIResources(); | 438 bool resource_lost = true; |
| 439 RecreateUIResources(resource_lost); |
| 439 | 440 |
| 440 num_failed_recreate_attempts_ = 0; | 441 num_failed_recreate_attempts_ = 0; |
| 441 output_surface_lost_ = true; | 442 output_surface_lost_ = true; |
| 442 SetNeedsCommit(); | 443 SetNeedsCommit(); |
| 443 } | 444 } |
| 444 | 445 |
| 445 bool LayerTreeHost::CompositeAndReadback(void* pixels, | 446 bool LayerTreeHost::CompositeAndReadback(void* pixels, |
| 446 gfx::Rect rect_in_device_viewport) { | 447 gfx::Rect rect_in_device_viewport) { |
| 447 trigger_idle_updates_ = false; | 448 trigger_idle_updates_ = false; |
| 448 bool ret = proxy_->CompositeAndReadback(pixels, rect_in_device_viewport); | 449 bool ret = proxy_->CompositeAndReadback(pixels, rect_in_device_viewport); |
| (...skipping 694 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1143 if (iter == ui_resource_client_map_.end()) | 1144 if (iter == ui_resource_client_map_.end()) |
| 1144 return; | 1145 return; |
| 1145 | 1146 |
| 1146 UIResourceRequest request; | 1147 UIResourceRequest request; |
| 1147 request.type = UIResourceRequest::UIResourceDelete; | 1148 request.type = UIResourceRequest::UIResourceDelete; |
| 1148 request.id = uid; | 1149 request.id = uid; |
| 1149 ui_resource_request_queue_.push_back(request); | 1150 ui_resource_request_queue_.push_back(request); |
| 1150 ui_resource_client_map_.erase(uid); | 1151 ui_resource_client_map_.erase(uid); |
| 1151 } | 1152 } |
| 1152 | 1153 |
| 1153 void LayerTreeHost::UIResourceLost(UIResourceId uid) { | 1154 void LayerTreeHost::RecreateUIResources(bool resource_lost) { |
| 1154 UIResourceClientMap::iterator iter = ui_resource_client_map_.find(uid); | |
| 1155 if (iter == ui_resource_client_map_.end()) | |
| 1156 return; | |
| 1157 | |
| 1158 UIResourceRequest request; | |
| 1159 bool resource_lost = true; | |
| 1160 request.type = UIResourceRequest::UIResourceCreate; | |
| 1161 request.id = uid; | |
| 1162 request.bitmap = iter->second->GetBitmap(uid, resource_lost); | |
| 1163 DCHECK(request.bitmap.get()); | |
| 1164 ui_resource_request_queue_.push_back(request); | |
| 1165 } | |
| 1166 | |
| 1167 void LayerTreeHost::DidLoseUIResources() { | |
| 1168 // When output surface is lost, we need to recreate the resource. | |
| 1169 for (UIResourceClientMap::iterator iter = ui_resource_client_map_.begin(); | 1155 for (UIResourceClientMap::iterator iter = ui_resource_client_map_.begin(); |
| 1170 iter != ui_resource_client_map_.end(); | 1156 iter != ui_resource_client_map_.end(); |
| 1171 ++iter) { | 1157 ++iter) { |
| 1172 UIResourceLost(iter->first); | 1158 UIResourceId uid = iter->first; |
| 1159 UIResourceRequest request; |
| 1160 request.type = UIResourceRequest::UIResourceCreate; |
| 1161 request.id = uid; |
| 1162 request.bitmap = iter->second->GetBitmap(uid, resource_lost); |
| 1163 DCHECK(request.bitmap.get()); |
| 1164 ui_resource_request_queue_.push_back(request); |
| 1173 } | 1165 } |
| 1174 } | 1166 } |
| 1175 | 1167 |
| 1176 } // namespace cc | 1168 } // namespace cc |
| OLD | NEW |