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

Unified Diff: cc/resources/tile_manager.cc

Issue 265883013: cc: Add a flag to layers that returns true if the layer is in RSLL. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: update Created 6 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 side-by-side diff with in-line comments
Download patch
Index: cc/resources/tile_manager.cc
diff --git a/cc/resources/tile_manager.cc b/cc/resources/tile_manager.cc
index 38948c3fa1ab921b01864c448fb5e7fb3d74ee65..3b26f41571936120aefd8001cbbdb8aec8a5fc78 100644
--- a/cc/resources/tile_manager.cc
+++ b/cc/resources/tile_manager.cc
@@ -685,6 +685,19 @@ void TileManager::GetTilesWithAssignedBins(PrioritizedTileSet* tiles) {
}
}
+void TileManager::CleanUpLayers() {
+ for (size_t i = 0; i < layers_.size(); ++i) {
+ if (layers_[i]->IsRenderSurfaceLayerListMember())
+ continue;
+
+ layers_[i]->DidUnregisterLayer();
+ std::swap(layers_[i], layers_.back());
+ layers_.pop_back();
+ --i;
+ prioritized_tiles_dirty_ = true;
+ }
+}
+
void TileManager::ManageTiles(const GlobalStateThatImpactsTilePriority& state) {
TRACE_EVENT0("cc", "TileManager::ManageTiles");
@@ -694,6 +707,8 @@ void TileManager::ManageTiles(const GlobalStateThatImpactsTilePriority& state) {
prioritized_tiles_dirty_ = true;
}
+ CleanUpLayers();
+
// We need to call CheckForCompletedTasks() once in-between each call
// to ScheduleTasks() to prevent canceled tasks from being scheduled.
if (!did_check_for_completed_tasks_since_last_schedule_tasks_) {

Powered by Google App Engine
This is Rietveld 408576698