Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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/layers/picture_layer.h" | 5 #include "cc/layers/picture_layer.h" |
| 6 | 6 |
| 7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
| 8 #include "base/trace_event/trace_event.h" | 8 #include "base/trace_event/trace_event.h" |
| 9 #include "cc/layers/content_layer_client.h" | 9 #include "cc/layers/content_layer_client.h" |
| 10 #include "cc/layers/picture_layer_impl.h" | 10 #include "cc/layers/picture_layer_impl.h" |
| 11 #include "cc/paint/paint_record.h" | 11 #include "cc/paint/paint_record.h" |
| 12 #include "cc/playback/recording_source.h" | 12 #include "cc/playback/recording_source.h" |
| 13 #include "cc/trees/layer_tree_host.h" | 13 #include "cc/trees/layer_tree_host.h" |
| 14 #include "cc/trees/layer_tree_impl.h" | 14 #include "cc/trees/layer_tree_impl.h" |
| 15 #include "ui/gfx/geometry/rect_conversions.h" | 15 #include "ui/gfx/geometry/rect_conversions.h" |
| 16 | 16 |
| 17 namespace cc { | 17 namespace cc { |
| 18 | 18 |
| 19 PictureLayer::PictureLayerInputs::PictureLayerInputs() = default; | 19 PictureLayer::PictureLayerInputs::PictureLayerInputs() = default; |
| 20 | 20 |
| 21 PictureLayer::PictureLayerInputs::~PictureLayerInputs() = default; | 21 PictureLayer::PictureLayerInputs::~PictureLayerInputs() = default; |
| 22 | 22 |
| 23 scoped_refptr<PictureLayer> PictureLayer::Create(ContentLayerClient* client) { | 23 scoped_refptr<PictureLayer> PictureLayer::Create(ContentLayerClient* client) { |
| 24 return make_scoped_refptr(new PictureLayer(client)); | 24 return make_scoped_refptr(new PictureLayer(client)); |
| 25 } | 25 } |
| 26 | 26 |
| 27 PictureLayer::PictureLayer(ContentLayerClient* client) | 27 PictureLayer::PictureLayer(ContentLayerClient* client) |
| 28 : instrumentation_object_tracker_(id()), | 28 : instrumentation_object_tracker_(id()), |
| 29 update_source_frame_number_(-1), | 29 update_source_frame_number_(-1), |
| 30 mask_type_(Layer::LayerMaskType::NOT_MASK) { | 30 mask_type_(LayerMaskType::NOT_MASK) { |
| 31 picture_layer_inputs_.client = client; | 31 picture_layer_inputs_.client = client; |
| 32 } | 32 } |
| 33 | 33 |
| 34 PictureLayer::PictureLayer(ContentLayerClient* client, | 34 PictureLayer::PictureLayer(ContentLayerClient* client, |
| 35 std::unique_ptr<RecordingSource> source) | 35 std::unique_ptr<RecordingSource> source) |
| 36 : PictureLayer(client) { | 36 : PictureLayer(client) { |
| 37 recording_source_ = std::move(source); | 37 recording_source_ = std::move(source); |
| 38 } | 38 } |
| 39 | 39 |
| 40 PictureLayer::~PictureLayer() { | 40 PictureLayer::~PictureLayer() { |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 61 recording_source_->CreateRasterSource(can_use_lcd_text); | 61 recording_source_->CreateRasterSource(can_use_lcd_text); |
| 62 layer_impl->set_gpu_raster_max_texture_size( | 62 layer_impl->set_gpu_raster_max_texture_size( |
| 63 layer_tree_host()->device_viewport_size()); | 63 layer_tree_host()->device_viewport_size()); |
| 64 layer_impl->UpdateRasterSource(raster_source, &last_updated_invalidation_, | 64 layer_impl->UpdateRasterSource(raster_source, &last_updated_invalidation_, |
| 65 nullptr); | 65 nullptr); |
| 66 DCHECK(last_updated_invalidation_.IsEmpty()); | 66 DCHECK(last_updated_invalidation_.IsEmpty()); |
| 67 } | 67 } |
| 68 | 68 |
| 69 void PictureLayer::SetLayerTreeHost(LayerTreeHost* host) { | 69 void PictureLayer::SetLayerTreeHost(LayerTreeHost* host) { |
| 70 Layer::SetLayerTreeHost(host); | 70 Layer::SetLayerTreeHost(host); |
| 71 if (host && !host->GetSettings().enable_mask_tiling && | |
| 72 mask_type_ == LayerMaskType::MULTI_TEXTURE_MASK) | |
| 73 mask_type_ = LayerMaskType::SINGLE_TEXTURE_MASK; | |
|
trchen
2017/02/16 23:52:30
nit: Move after line 77 then null-check for host c
| |
| 74 | |
| 71 if (!host) | 75 if (!host) |
| 72 return; | 76 return; |
| 73 | 77 |
| 74 if (!recording_source_) | 78 if (!recording_source_) |
| 75 recording_source_.reset(new RecordingSource); | 79 recording_source_.reset(new RecordingSource); |
| 76 recording_source_->SetSlowdownRasterScaleFactor( | 80 recording_source_->SetSlowdownRasterScaleFactor( |
| 77 host->GetDebugState().slow_down_raster_scale_factor); | 81 host->GetDebugState().slow_down_raster_scale_factor); |
| 78 // If we need to enable image decode tasks, then we have to generate the | 82 // If we need to enable image decode tasks, then we have to generate the |
| 79 // discardable images metadata. | 83 // discardable images metadata. |
| 80 const LayerTreeSettings& settings = layer_tree_host()->GetSettings(); | 84 const LayerTreeSettings& settings = layer_tree_host()->GetSettings(); |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 130 SetNeedsPushProperties(); | 134 SetNeedsPushProperties(); |
| 131 } else { | 135 } else { |
| 132 // If this invalidation did not affect the recording source, then it can be | 136 // If this invalidation did not affect the recording source, then it can be |
| 133 // cleared as an optimization. | 137 // cleared as an optimization. |
| 134 last_updated_invalidation_.Clear(); | 138 last_updated_invalidation_.Clear(); |
| 135 } | 139 } |
| 136 | 140 |
| 137 return updated; | 141 return updated; |
| 138 } | 142 } |
| 139 | 143 |
| 140 void PictureLayer::SetLayerMaskType(Layer::LayerMaskType mask_type) { | 144 void PictureLayer::SetLayerMaskType(LayerMaskType mask_type) { |
| 141 mask_type_ = mask_type; | 145 mask_type_ = mask_type; |
| 142 } | 146 } |
| 143 | 147 |
| 144 sk_sp<SkPicture> PictureLayer::GetPicture() const { | 148 sk_sp<SkPicture> PictureLayer::GetPicture() const { |
| 145 // We could either flatten the RecordingSource into a single SkPicture, or | 149 // We could either flatten the RecordingSource into a single SkPicture, or |
| 146 // paint a fresh one depending on what we intend to do with it. For now we | 150 // paint a fresh one depending on what we intend to do with it. For now we |
| 147 // just paint a fresh one to get consistent results. | 151 // just paint a fresh one to get consistent results. |
| 148 if (!DrawsContent()) | 152 if (!DrawsContent()) |
| 149 return nullptr; | 153 return nullptr; |
| 150 | 154 |
| (...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 226 picture_layer_inputs_.display_list = nullptr; | 230 picture_layer_inputs_.display_list = nullptr; |
| 227 picture_layer_inputs_.painter_reported_memory_usage = 0; | 231 picture_layer_inputs_.painter_reported_memory_usage = 0; |
| 228 } | 232 } |
| 229 } | 233 } |
| 230 | 234 |
| 231 const DisplayItemList* PictureLayer::GetDisplayItemList() { | 235 const DisplayItemList* PictureLayer::GetDisplayItemList() { |
| 232 return picture_layer_inputs_.display_list.get(); | 236 return picture_layer_inputs_.display_list.get(); |
| 233 } | 237 } |
| 234 | 238 |
| 235 } // namespace cc | 239 } // namespace cc |
| OLD | NEW |