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

Side by Side Diff: cc/layers/picture_layer.cc

Issue 373113003: Keeping track of descendants that draw content instead of recalcualting (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 5 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 unified diff | Download patch
OLDNEW
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 "cc/layers/content_layer_client.h" 7 #include "cc/layers/content_layer_client.h"
8 #include "cc/layers/picture_layer_impl.h" 8 #include "cc/layers/picture_layer_impl.h"
9 #include "cc/trees/layer_tree_impl.h" 9 #include "cc/trees/layer_tree_impl.h"
10 #include "third_party/skia/include/core/SkPictureRecorder.h" 10 #include "third_party/skia/include/core/SkPictureRecorder.h"
(...skipping 10 matching lines...) Expand all
21 pile_(make_scoped_refptr(new PicturePile())), 21 pile_(make_scoped_refptr(new PicturePile())),
22 instrumentation_object_tracker_(id()), 22 instrumentation_object_tracker_(id()),
23 is_mask_(false), 23 is_mask_(false),
24 update_source_frame_number_(-1), 24 update_source_frame_number_(-1),
25 can_use_lcd_text_last_frame_(can_use_lcd_text()) { 25 can_use_lcd_text_last_frame_(can_use_lcd_text()) {
26 } 26 }
27 27
28 PictureLayer::~PictureLayer() { 28 PictureLayer::~PictureLayer() {
29 } 29 }
30 30
31 bool PictureLayer::DrawsContent() const {
32 return Layer::DrawsContent() && client_;
33 }
34
35 scoped_ptr<LayerImpl> PictureLayer::CreateLayerImpl(LayerTreeImpl* tree_impl) { 31 scoped_ptr<LayerImpl> PictureLayer::CreateLayerImpl(LayerTreeImpl* tree_impl) {
36 return PictureLayerImpl::Create(tree_impl, id()).PassAs<LayerImpl>(); 32 return PictureLayerImpl::Create(tree_impl, id()).PassAs<LayerImpl>();
37 } 33 }
38 34
39 void PictureLayer::PushPropertiesTo(LayerImpl* base_layer) { 35 void PictureLayer::PushPropertiesTo(LayerImpl* base_layer) {
40 Layer::PushPropertiesTo(base_layer); 36 Layer::PushPropertiesTo(base_layer);
41 PictureLayerImpl* layer_impl = static_cast<PictureLayerImpl*>(base_layer); 37 PictureLayerImpl* layer_impl = static_cast<PictureLayerImpl*>(base_layer);
42 38
43 if (layer_impl->bounds().IsEmpty()) { 39 if (layer_impl->bounds().IsEmpty()) {
44 // Update may not get called for an empty layer, so resize here instead. 40 // Update may not get called for an empty layer, so resize here instead.
(...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after
193 &opaque, 189 &opaque,
194 ContentLayerClient::GRAPHICS_CONTEXT_ENABLED); 190 ContentLayerClient::GRAPHICS_CONTEXT_ENABLED);
195 skia::RefPtr<SkPicture> picture = skia::AdoptRef(recorder.endRecording()); 191 skia::RefPtr<SkPicture> picture = skia::AdoptRef(recorder.endRecording());
196 return picture; 192 return picture;
197 } 193 }
198 194
199 bool PictureLayer::IsSuitableForGpuRasterization() const { 195 bool PictureLayer::IsSuitableForGpuRasterization() const {
200 return pile_->is_suitable_for_gpu_rasterization(); 196 return pile_->is_suitable_for_gpu_rasterization();
201 } 197 }
202 198
199 void PictureLayer::ClearClient() {
200 client_ = NULL;
201 UpdateDrawsContent(HasDrawableContent());
danakj 2014/08/06 14:57:08 Do we need to call this in the Constructor as well
awoloszyn 2014/08/08 15:53:20 There is no need in this case, since it will still
202 }
203
204 bool PictureLayer::HasDrawableContent() const {
205 return client_ && Layer::HasDrawableContent();
206 }
207
203 void PictureLayer::RunMicroBenchmark(MicroBenchmark* benchmark) { 208 void PictureLayer::RunMicroBenchmark(MicroBenchmark* benchmark) {
204 benchmark->RunOnLayer(this); 209 benchmark->RunOnLayer(this);
205 } 210 }
206 211
207 } // namespace cc 212 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698