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

Side by Side Diff: cc/layers/ui_resource_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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/ui_resource_layer.h" 5 #include "cc/layers/ui_resource_layer.h"
6 6
7 #include "cc/layers/ui_resource_layer_impl.h" 7 #include "cc/layers/ui_resource_layer_impl.h"
8 #include "cc/resources/prioritized_resource.h" 8 #include "cc/resources/prioritized_resource.h"
9 #include "cc/resources/resource_update.h" 9 #include "cc/resources/resource_update.h"
10 #include "cc/resources/resource_update_queue.h" 10 #include "cc/resources/resource_update_queue.h"
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after
106 return; 106 return;
107 107
108 Layer::SetLayerTreeHost(host); 108 Layer::SetLayerTreeHost(host);
109 109
110 // Recreate the resource hold against the new LTH. 110 // Recreate the resource hold against the new LTH.
111 RecreateUIResourceHolder(); 111 RecreateUIResourceHolder();
112 } 112 }
113 113
114 void UIResourceLayer::RecreateUIResourceHolder() { 114 void UIResourceLayer::RecreateUIResourceHolder() {
115 ui_resource_holder_.reset(); 115 ui_resource_holder_.reset();
116 if (!layer_tree_host() || bitmap_.empty()) 116 if (!layer_tree_host() || bitmap_.empty()) {
danakj 2014/07/17 17:21:25 can you invert this and drop teh early out so we o
awoloszyn 2014/07/17 20:45:00 Done.
117 UpdateDrawsContent(HasDrawableContent());
117 return; 118 return;
119 }
118 120
119 ui_resource_holder_ = 121 ui_resource_holder_ =
120 ScopedUIResourceHolder::Create(layer_tree_host(), bitmap_); 122 ScopedUIResourceHolder::Create(layer_tree_host(), bitmap_);
123 UpdateDrawsContent(HasDrawableContent());
121 } 124 }
122 125
123 void UIResourceLayer::SetBitmap(const SkBitmap& skbitmap) { 126 void UIResourceLayer::SetBitmap(const SkBitmap& skbitmap) {
124 bitmap_ = skbitmap; 127 bitmap_ = skbitmap;
125 128
126 RecreateUIResourceHolder(); 129 RecreateUIResourceHolder();
127 SetNeedsCommit(); 130 SetNeedsCommit();
128 } 131 }
129 132
130 void UIResourceLayer::SetUIResourceId(UIResourceId resource_id) { 133 void UIResourceLayer::SetUIResourceId(UIResourceId resource_id) {
131 if (ui_resource_holder_ && ui_resource_holder_->id() == resource_id) 134 if (ui_resource_holder_ && ui_resource_holder_->id() == resource_id)
132 return; 135 return;
133 136
134 if (resource_id) { 137 if (resource_id) {
135 ui_resource_holder_ = SharedUIResourceHolder::Create(resource_id); 138 ui_resource_holder_ = SharedUIResourceHolder::Create(resource_id);
136 } else { 139 } else {
137 ui_resource_holder_.reset(); 140 ui_resource_holder_.reset();
138 } 141 }
139 142
143 UpdateDrawsContent(HasDrawableContent());
140 SetNeedsCommit(); 144 SetNeedsCommit();
141 } 145 }
142 146
143 bool UIResourceLayer::DrawsContent() const { 147 bool UIResourceLayer::HasDrawableContent() const {
144 return ui_resource_holder_ && ui_resource_holder_->id() && 148 return ui_resource_holder_ && ui_resource_holder_->id() &&
145 Layer::DrawsContent(); 149 Layer::HasDrawableContent();
146 } 150 }
147 151
148 void UIResourceLayer::PushPropertiesTo(LayerImpl* layer) { 152 void UIResourceLayer::PushPropertiesTo(LayerImpl* layer) {
149 Layer::PushPropertiesTo(layer); 153 Layer::PushPropertiesTo(layer);
150 UIResourceLayerImpl* layer_impl = static_cast<UIResourceLayerImpl*>(layer); 154 UIResourceLayerImpl* layer_impl = static_cast<UIResourceLayerImpl*>(layer);
151 155
152 if (!ui_resource_holder_) { 156 if (!ui_resource_holder_) {
153 layer_impl->SetUIResourceId(0); 157 layer_impl->SetUIResourceId(0);
154 } else { 158 } else {
155 DCHECK(layer_tree_host()); 159 DCHECK(layer_tree_host());
156 160
157 gfx::Size image_size = 161 gfx::Size image_size =
158 layer_tree_host()->GetUIResourceSize(ui_resource_holder_->id()); 162 layer_tree_host()->GetUIResourceSize(ui_resource_holder_->id());
159 layer_impl->SetUIResourceId(ui_resource_holder_->id()); 163 layer_impl->SetUIResourceId(ui_resource_holder_->id());
160 layer_impl->SetImageBounds(image_size); 164 layer_impl->SetImageBounds(image_size);
161 layer_impl->SetUV(uv_top_left_, uv_bottom_right_); 165 layer_impl->SetUV(uv_top_left_, uv_bottom_right_);
162 layer_impl->SetVertexOpacity(vertex_opacity_); 166 layer_impl->SetVertexOpacity(vertex_opacity_);
163 } 167 }
164 } 168 }
165 169
166 } // namespace cc 170 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698