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 |