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

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

Issue 2322943003: cc: Move UI Resource management out of LayerTreeHost. (Closed)
Patch Set: format Created 4 years, 3 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 "base/memory/ptr_util.h" 7 #include "base/memory/ptr_util.h"
8 #include "base/trace_event/trace_event.h" 8 #include "base/trace_event/trace_event.h"
9 #include "cc/layers/ui_resource_layer_impl.h" 9 #include "cc/layers/ui_resource_layer_impl.h"
10 #include "cc/resources/scoped_ui_resource.h" 10 #include "cc/resources/scoped_ui_resource.h"
11 #include "cc/resources/ui_resource_bitmap.h" 11 #include "cc/resources/ui_resource_bitmap.h"
12 #include "cc/resources/ui_resource_manager.h"
12 #include "cc/trees/layer_tree_host.h" 13 #include "cc/trees/layer_tree_host.h"
13 14
14 namespace cc { 15 namespace cc {
15 16
16 17
17 namespace { 18 namespace {
18 19
19 class ScopedUIResourceHolder : public UIResourceLayer::UIResourceHolder { 20 class ScopedUIResourceHolder : public UIResourceLayer::UIResourceHolder {
20 public: 21 public:
21 static std::unique_ptr<ScopedUIResourceHolder> Create( 22 static std::unique_ptr<ScopedUIResourceHolder> Create(
22 LayerTreeHost* host, 23 UIResourceManager* ui_resource_manager,
23 const SkBitmap& skbitmap) { 24 const SkBitmap& skbitmap) {
24 return base::WrapUnique(new ScopedUIResourceHolder(host, skbitmap)); 25 return base::WrapUnique(
26 new ScopedUIResourceHolder(ui_resource_manager, skbitmap));
25 } 27 }
26 UIResourceId id() override { return resource_->id(); } 28 UIResourceId id() override { return resource_->id(); }
27 29
28 private: 30 private:
29 ScopedUIResourceHolder(LayerTreeHost* host, const SkBitmap& skbitmap) { 31 ScopedUIResourceHolder(UIResourceManager* ui_resource_manager,
30 resource_ = ScopedUIResource::Create(host, UIResourceBitmap(skbitmap)); 32 const SkBitmap& skbitmap) {
33 resource_ = ScopedUIResource::Create(ui_resource_manager,
34 UIResourceBitmap(skbitmap));
31 } 35 }
32 36
33 std::unique_ptr<ScopedUIResource> resource_; 37 std::unique_ptr<ScopedUIResource> resource_;
34 }; 38 };
35 39
36 class SharedUIResourceHolder : public UIResourceLayer::UIResourceHolder { 40 class SharedUIResourceHolder : public UIResourceLayer::UIResourceHolder {
37 public: 41 public:
38 static std::unique_ptr<SharedUIResourceHolder> Create(UIResourceId id) { 42 static std::unique_ptr<SharedUIResourceHolder> Create(UIResourceId id) {
39 return base::WrapUnique(new SharedUIResourceHolder(id)); 43 return base::WrapUnique(new SharedUIResourceHolder(id));
40 } 44 }
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after
111 UpdateDrawsContent(HasDrawableContent()); 115 UpdateDrawsContent(HasDrawableContent());
112 } 116 }
113 117
114 void UIResourceLayer::RecreateUIResourceHolder() { 118 void UIResourceLayer::RecreateUIResourceHolder() {
115 if (!bitmap_.empty()) 119 if (!bitmap_.empty())
116 SetBitmap(bitmap_); 120 SetBitmap(bitmap_);
117 } 121 }
118 122
119 void UIResourceLayer::SetBitmap(const SkBitmap& skbitmap) { 123 void UIResourceLayer::SetBitmap(const SkBitmap& skbitmap) {
120 bitmap_ = skbitmap; 124 bitmap_ = skbitmap;
121 if (layer_tree_host() && !bitmap_.empty()) { 125 if (GetLayerTree() && !bitmap_.empty()) {
122 ui_resource_holder_ = 126 ui_resource_holder_ = ScopedUIResourceHolder::Create(
123 ScopedUIResourceHolder::Create(layer_tree_host(), bitmap_); 127 GetLayerTree()->GetUIResourceManager(), bitmap_);
danakj 2016/09/08 20:57:35 How about storing the UIResourceManager* in SetLay
Khushal 2016/09/08 22:05:24 Finally the SetLayerTreeHost will change to SetLay
danakj 2016/09/08 22:37:12 I see, and since layers can change trees it wont m
Khushal 2016/09/08 23:56:05 I was mostly just moving code here so my understan
124 } else { 128 } else {
125 ui_resource_holder_ = nullptr; 129 ui_resource_holder_ = nullptr;
126 } 130 }
127 UpdateDrawsContent(HasDrawableContent()); 131 UpdateDrawsContent(HasDrawableContent());
128 SetNeedsCommit(); 132 SetNeedsCommit();
129 } 133 }
130 134
131 void UIResourceLayer::SetUIResourceId(UIResourceId resource_id) { 135 void UIResourceLayer::SetUIResourceId(UIResourceId resource_id) {
132 if (ui_resource_holder_ && ui_resource_holder_->id() == resource_id) 136 if (ui_resource_holder_ && ui_resource_holder_->id() == resource_id)
133 return; 137 return;
(...skipping 16 matching lines...) Expand all
150 } 154 }
151 155
152 void UIResourceLayer::PushPropertiesTo(LayerImpl* layer) { 156 void UIResourceLayer::PushPropertiesTo(LayerImpl* layer) {
153 Layer::PushPropertiesTo(layer); 157 Layer::PushPropertiesTo(layer);
154 TRACE_EVENT0("cc", "UIResourceLayer::PushPropertiesTo"); 158 TRACE_EVENT0("cc", "UIResourceLayer::PushPropertiesTo");
155 UIResourceLayerImpl* layer_impl = static_cast<UIResourceLayerImpl*>(layer); 159 UIResourceLayerImpl* layer_impl = static_cast<UIResourceLayerImpl*>(layer);
156 160
157 if (!ui_resource_holder_) { 161 if (!ui_resource_holder_) {
158 layer_impl->SetUIResourceId(0); 162 layer_impl->SetUIResourceId(0);
159 } else { 163 } else {
160 DCHECK(layer_tree_host()); 164 DCHECK(GetLayerTree());
161 165
162 gfx::Size image_size = 166 gfx::Size image_size =
163 layer_tree_host()->GetUIResourceSize(ui_resource_holder_->id()); 167 GetLayerTree()->GetUIResourceManager()->GetUIResourceSize(
168 ui_resource_holder_->id());
164 layer_impl->SetUIResourceId(ui_resource_holder_->id()); 169 layer_impl->SetUIResourceId(ui_resource_holder_->id());
165 layer_impl->SetImageBounds(image_size); 170 layer_impl->SetImageBounds(image_size);
166 layer_impl->SetUV(uv_top_left_, uv_bottom_right_); 171 layer_impl->SetUV(uv_top_left_, uv_bottom_right_);
167 layer_impl->SetVertexOpacity(vertex_opacity_); 172 layer_impl->SetVertexOpacity(vertex_opacity_);
168 } 173 }
169 } 174 }
170 175
171 } // namespace cc 176 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698