| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/resources/raster_tile_priority_queue_required.h" | 5 #include "cc/resources/raster_tile_priority_queue_required.h" |
| 6 | 6 |
| 7 #include "base/containers/hash_tables.h" |
| 7 #include "cc/resources/tiling_set_raster_queue_required.h" | 8 #include "cc/resources/tiling_set_raster_queue_required.h" |
| 8 | 9 |
| 9 namespace cc { | 10 namespace cc { |
| 10 | 11 |
| 11 RasterTilePriorityQueueRequired::RasterTilePriorityQueueRequired() { | 12 RasterTilePriorityQueueRequired::RasterTilePriorityQueueRequired() { |
| 12 } | 13 } |
| 13 | 14 |
| 14 RasterTilePriorityQueueRequired::~RasterTilePriorityQueueRequired() { | 15 RasterTilePriorityQueueRequired::~RasterTilePriorityQueueRequired() { |
| 15 } | 16 } |
| 16 | 17 |
| 17 void RasterTilePriorityQueueRequired::Build( | 18 void RasterTilePriorityQueueRequired::Build( |
| 18 const std::vector<PictureLayerImpl::Pair>& paired_layers, | 19 const base::hash_map<int, PictureLayerTilingSet::Pair>& |
| 20 paired_picture_layer_tiling_sets, |
| 21 bool has_pending_tree, |
| 19 Type type) { | 22 Type type) { |
| 20 DCHECK_NE(static_cast<int>(type), static_cast<int>(Type::ALL)); | 23 for (const auto& paired_tiling_set_pair : paired_picture_layer_tiling_sets) { |
| 21 for (const auto& pair : paired_layers) { | 24 const auto& paired_tiling_set = paired_tiling_set_pair.second; |
| 22 PictureLayerTilingSet* tiling_set = nullptr; | 25 PictureLayerTilingSet* tiling_set = nullptr; |
| 23 if (type == Type::REQUIRED_FOR_DRAW && pair.active) | 26 switch (type) { |
| 24 tiling_set = pair.active->picture_layer_tiling_set(); | 27 case Type::REQUIRED_FOR_DRAW: { |
| 25 else if (type == Type::REQUIRED_FOR_ACTIVATION && pair.pending) | 28 PictureLayerTilingSet* active = paired_tiling_set.active; |
| 26 tiling_set = pair.pending->picture_layer_tiling_set(); | 29 if (active && active->HasValidTilePriorities()) |
| 30 tiling_set = active; |
| 31 break; |
| 32 } |
| 33 case Type::REQUIRED_FOR_ACTIVATION: { |
| 34 PictureLayerTilingSet* pending = paired_tiling_set.pending; |
| 35 if (has_pending_tree && pending && pending->HasValidTilePriorities()) |
| 36 tiling_set = pending; |
| 37 break; |
| 38 } |
| 39 case Type::ALL: |
| 40 NOTREACHED(); |
| 41 break; |
| 42 } |
| 27 | 43 |
| 28 if (!tiling_set) | 44 if (!tiling_set) |
| 29 continue; | 45 continue; |
| 30 | 46 |
| 31 scoped_ptr<TilingSetRasterQueueRequired> tiling_set_queue( | 47 scoped_ptr<TilingSetRasterQueueRequired> tiling_set_queue( |
| 32 new TilingSetRasterQueueRequired(tiling_set, type)); | 48 new TilingSetRasterQueueRequired(tiling_set, type)); |
| 33 if (tiling_set_queue->IsEmpty()) | 49 if (tiling_set_queue->IsEmpty()) |
| 34 continue; | 50 continue; |
| 35 tiling_set_queues_.push_back(tiling_set_queue.Pass()); | 51 tiling_set_queues_.push_back(tiling_set_queue.Pass()); |
| 36 } | 52 } |
| 37 } | 53 } |
| 38 | 54 |
| 39 bool RasterTilePriorityQueueRequired::IsEmpty() const { | 55 bool RasterTilePriorityQueueRequired::IsEmpty() const { |
| 40 return tiling_set_queues_.empty(); | 56 return tiling_set_queues_.empty(); |
| 41 } | 57 } |
| 42 | 58 |
| 43 Tile* RasterTilePriorityQueueRequired::Top() { | 59 Tile* RasterTilePriorityQueueRequired::Top() { |
| 44 DCHECK(!IsEmpty()); | 60 DCHECK(!IsEmpty()); |
| 45 return tiling_set_queues_.back()->Top(); | 61 return tiling_set_queues_.back()->Top(); |
| 46 } | 62 } |
| 47 | 63 |
| 48 void RasterTilePriorityQueueRequired::Pop() { | 64 void RasterTilePriorityQueueRequired::Pop() { |
| 49 DCHECK(!IsEmpty()); | 65 DCHECK(!IsEmpty()); |
| 50 tiling_set_queues_.back()->Pop(); | 66 tiling_set_queues_.back()->Pop(); |
| 51 if (tiling_set_queues_.back()->IsEmpty()) | 67 if (tiling_set_queues_.back()->IsEmpty()) |
| 52 tiling_set_queues_.pop_back(); | 68 tiling_set_queues_.pop_back(); |
| 53 } | 69 } |
| 54 | 70 |
| 55 } // namespace cc | 71 } // namespace cc |
| OLD | NEW |