| 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 "cc/resources/tiling_set_raster_queue_required.h" | 7 #include "cc/resources/tiling_set_raster_queue_required.h" |
| 8 | 8 |
| 9 namespace cc { | 9 namespace cc { |
| 10 | 10 |
| 11 RasterTilePriorityQueueRequired::RasterTilePriorityQueueRequired() { | 11 RasterTilePriorityQueueRequired::RasterTilePriorityQueueRequired() { |
| 12 } | 12 } |
| 13 | 13 |
| 14 RasterTilePriorityQueueRequired::~RasterTilePriorityQueueRequired() { | 14 RasterTilePriorityQueueRequired::~RasterTilePriorityQueueRequired() { |
| 15 } | 15 } |
| 16 | 16 |
| 17 void RasterTilePriorityQueueRequired::Build( | 17 void RasterTilePriorityQueueRequired::Build( |
| 18 const std::vector<PictureLayerImpl::Pair>& paired_layers, | 18 const std::vector<PictureLayerImpl::Pair>& paired_layers, |
| 19 Type type) { | 19 Type type) { |
| 20 DCHECK_NE(static_cast<int>(type), static_cast<int>(Type::ALL)); | 20 DCHECK_NE(static_cast<int>(type), static_cast<int>(Type::ALL)); |
| 21 if (type == Type::REQUIRED_FOR_DRAW) |
| 22 BuildRequiredForDraw(paired_layers); |
| 23 else |
| 24 BuildRequiredForActivation(paired_layers); |
| 25 } |
| 26 |
| 27 void RasterTilePriorityQueueRequired::BuildRequiredForDraw( |
| 28 const std::vector<PictureLayerImpl::Pair>& paired_layers) { |
| 21 for (const auto& pair : paired_layers) { | 29 for (const auto& pair : paired_layers) { |
| 22 PictureLayerTilingSet* tiling_set = nullptr; | 30 if (!pair.active) |
| 23 if (type == Type::REQUIRED_FOR_DRAW && pair.active) | |
| 24 tiling_set = pair.active->picture_layer_tiling_set(); | |
| 25 else if (type == Type::REQUIRED_FOR_ACTIVATION && pair.pending) | |
| 26 tiling_set = pair.pending->picture_layer_tiling_set(); | |
| 27 | |
| 28 if (!tiling_set) | |
| 29 continue; | 31 continue; |
| 30 | |
| 31 scoped_ptr<TilingSetRasterQueueRequired> tiling_set_queue( | 32 scoped_ptr<TilingSetRasterQueueRequired> tiling_set_queue( |
| 32 new TilingSetRasterQueueRequired(tiling_set, type)); | 33 new TilingSetRasterQueueRequired( |
| 34 pair.active->picture_layer_tiling_set(), Type::REQUIRED_FOR_DRAW)); |
| 33 if (tiling_set_queue->IsEmpty()) | 35 if (tiling_set_queue->IsEmpty()) |
| 34 continue; | 36 continue; |
| 35 tiling_set_queues_.push_back(tiling_set_queue.Pass()); | 37 tiling_set_queues_.push_back(tiling_set_queue.Pass()); |
| 36 } | 38 } |
| 37 } | 39 } |
| 38 | 40 |
| 41 void RasterTilePriorityQueueRequired::BuildRequiredForActivation( |
| 42 const std::vector<PictureLayerImpl::Pair>& paired_layers) { |
| 43 for (const auto& pair : paired_layers) { |
| 44 if (pair.active) { |
| 45 scoped_ptr<TilingSetRasterQueueRequired> tiling_set_queue( |
| 46 new TilingSetRasterQueueRequired( |
| 47 pair.active->picture_layer_tiling_set(), |
| 48 Type::REQUIRED_FOR_ACTIVATION)); |
| 49 if (!tiling_set_queue->IsEmpty()) |
| 50 tiling_set_queues_.push_back(tiling_set_queue.Pass()); |
| 51 } |
| 52 if (pair.pending) { |
| 53 scoped_ptr<TilingSetRasterQueueRequired> tiling_set_queue( |
| 54 new TilingSetRasterQueueRequired( |
| 55 pair.pending->picture_layer_tiling_set(), |
| 56 Type::REQUIRED_FOR_ACTIVATION)); |
| 57 if (!tiling_set_queue->IsEmpty()) |
| 58 tiling_set_queues_.push_back(tiling_set_queue.Pass()); |
| 59 } |
| 60 } |
| 61 } |
| 62 |
| 39 bool RasterTilePriorityQueueRequired::IsEmpty() const { | 63 bool RasterTilePriorityQueueRequired::IsEmpty() const { |
| 40 return tiling_set_queues_.empty(); | 64 return tiling_set_queues_.empty(); |
| 41 } | 65 } |
| 42 | 66 |
| 43 Tile* RasterTilePriorityQueueRequired::Top() { | 67 Tile* RasterTilePriorityQueueRequired::Top() { |
| 44 DCHECK(!IsEmpty()); | 68 DCHECK(!IsEmpty()); |
| 45 return tiling_set_queues_.back()->Top(); | 69 return tiling_set_queues_.back()->Top(); |
| 46 } | 70 } |
| 47 | 71 |
| 48 void RasterTilePriorityQueueRequired::Pop() { | 72 void RasterTilePriorityQueueRequired::Pop() { |
| 49 DCHECK(!IsEmpty()); | 73 DCHECK(!IsEmpty()); |
| 50 tiling_set_queues_.back()->Pop(); | 74 tiling_set_queues_.back()->Pop(); |
| 51 if (tiling_set_queues_.back()->IsEmpty()) | 75 if (tiling_set_queues_.back()->IsEmpty()) |
| 52 tiling_set_queues_.pop_back(); | 76 tiling_set_queues_.pop_back(); |
| 53 } | 77 } |
| 54 | 78 |
| 55 } // namespace cc | 79 } // namespace cc |
| OLD | NEW |