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

Side by Side Diff: content/browser/android/overscroll_glow.cc

Issue 377013002: android: Use UIResource for overscroll glow (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: addressed comments. moved resource loading to its own class. 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 (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 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 "content/browser/android/overscroll_glow.h" 5 #include "content/browser/android/overscroll_glow.h"
6 6
7 #include "base/debug/trace_event.h" 7 #include "base/debug/trace_event.h"
8 #include "base/lazy_instance.h" 8 #include "base/lazy_instance.h"
9 #include "base/threading/worker_pool.h" 9 #include "cc/layers/ui_resource_layer.h"
10 #include "cc/layers/image_layer.h"
11 #include "content/browser/android/edge_effect.h" 10 #include "content/browser/android/edge_effect.h"
12 #include "skia/ext/image_operations.h" 11 #include "ui/base/android/system_ui_resource.h"
13 #include "ui/gfx/android/java_bitmap.h" 12 #include "ui/base/android/system_ui_resource_layer.h"
13 #include "ui/base/android/system_ui_resource_manager.h"
14 14
15 using std::max; 15 using std::max;
16 using std::min; 16 using std::min;
17 17
18 namespace content { 18 namespace content {
19 19
20 namespace { 20 namespace {
21 21
22 const float kEpsilon = 1e-3f; 22 const float kEpsilon = 1e-3f;
23 const int kScaledEdgeHeight = 12;
24 const int kScaledGlowHeight = 64;
25 const float kEdgeHeightAtMdpi = 12.f; 23 const float kEdgeHeightAtMdpi = 12.f;
26 const float kGlowHeightAtMdpi = 128.f; 24 const float kGlowHeightAtMdpi = 128.f;
27 25
28 SkBitmap CreateSkBitmapFromAndroidResource(const char* name, gfx::Size size) {
29 base::android::ScopedJavaLocalRef<jobject> jobj =
30 gfx::CreateJavaBitmapFromAndroidResource(name, size);
31 if (jobj.is_null())
32 return SkBitmap();
33
34 SkBitmap bitmap = CreateSkBitmapFromJavaBitmap(gfx::JavaBitmap(jobj.obj()));
35 if (bitmap.isNull())
36 return bitmap;
37
38 return skia::ImageOperations::Resize(
39 bitmap, skia::ImageOperations::RESIZE_BOX, size.width(), size.height());
40 }
41
42 class OverscrollResources {
43 public:
44 OverscrollResources() {
45 TRACE_EVENT0("browser", "OverscrollResources::Create");
46 edge_bitmap_ =
47 CreateSkBitmapFromAndroidResource("android:drawable/overscroll_edge",
48 gfx::Size(128, kScaledEdgeHeight));
49 glow_bitmap_ =
50 CreateSkBitmapFromAndroidResource("android:drawable/overscroll_glow",
51 gfx::Size(128, kScaledGlowHeight));
52 }
53
54 const SkBitmap& edge_bitmap() const { return edge_bitmap_; }
55 const SkBitmap& glow_bitmap() const { return glow_bitmap_; }
56
57 private:
58 SkBitmap edge_bitmap_;
59 SkBitmap glow_bitmap_;
60
61 DISALLOW_COPY_AND_ASSIGN(OverscrollResources);
62 };
63
64 // Leaky to allow access from a worker thread.
65 base::LazyInstance<OverscrollResources>::Leaky g_overscroll_resources =
66 LAZY_INSTANCE_INITIALIZER;
67
68 scoped_refptr<cc::Layer> CreateImageLayer(const SkBitmap& bitmap) {
69 scoped_refptr<cc::ImageLayer> layer = cc::ImageLayer::Create();
70 layer->SetBitmap(bitmap);
71 return layer;
72 }
73
74 bool IsApproxZero(float value) { 26 bool IsApproxZero(float value) {
75 return std::abs(value) < kEpsilon; 27 return std::abs(value) < kEpsilon;
76 } 28 }
77 29
78 gfx::Vector2dF ZeroSmallComponents(gfx::Vector2dF vector) { 30 gfx::Vector2dF ZeroSmallComponents(gfx::Vector2dF vector) {
79 if (IsApproxZero(vector.x())) 31 if (IsApproxZero(vector.x()))
80 vector.set_x(0); 32 vector.set_x(0);
81 if (IsApproxZero(vector.y())) 33 if (IsApproxZero(vector.y()))
82 vector.set_y(0); 34 vector.set_y(0);
83 return vector; 35 return vector;
84 } 36 }
85 37
86 // Force loading of any necessary resources. This function is thread-safe. 38 class OverscrollGlowLayer : public ui::SystemUIResourceLayer,
87 void EnsureResources() { 39 public OverscrollGlowLayerWrapper {
88 g_overscroll_resources.Get(); 40 public:
41 static scoped_ptr<OverscrollGlowLayer> Create(
42 ui::SystemUIResource::Type type,
43 ui::SystemUIResourceManager* resource_manager) {
44 return make_scoped_ptr(new OverscrollGlowLayer(type, resource_manager));
45 }
46
47 // ui::SystemUIResourceLayer implementation
48 virtual void SetUIResourceId(cc::UIResourceId id) OVERRIDE {
49 ui_resource_layer_->SetUIResourceId(id);
50 }
51
52 // OverscrollGlowLayerWrapper implementation
53 virtual scoped_refptr<cc::Layer> layer() OVERRIDE {
54 return ui_resource_layer_;
55 }
56
57 virtual ~OverscrollGlowLayer() {
58 resource_manager_->Unsubscribe(type_, this);
59 ui_resource_layer_->RemoveFromParent();
60 }
61
62 private:
63 OverscrollGlowLayer(ui::SystemUIResource::Type type,
64 ui::SystemUIResourceManager* resource_manager)
65 : ui_resource_layer_(cc::UIResourceLayer::Create()),
66 type_(type),
67 resource_manager_(resource_manager) {
68 resource_manager_->Subscribe(type_, this);
69 }
70
71 scoped_refptr<cc::UIResourceLayer> ui_resource_layer_;
72 ui::SystemUIResource::Type type_;
73 ui::SystemUIResourceManager* resource_manager_;
74
75 DISALLOW_COPY_AND_ASSIGN(OverscrollGlowLayer);
76 };
77
78 } // namespace
79
80 scoped_ptr<OverscrollGlow> OverscrollGlow::Create(
81 ui::SystemUIResourceManager* resource_manager) {
82 return make_scoped_ptr(new OverscrollGlow(resource_manager));
89 } 83 }
90 84
91 } // namespace 85 OverscrollGlow::OverscrollGlow(ui::SystemUIResourceManager* resource_manager)
92 86 : enabled_(true), initialized_(false), resource_manager_(resource_manager) {
93 scoped_ptr<OverscrollGlow> OverscrollGlow::Create(bool enabled) {
94 // Don't block the main thread with effect resource loading during creation.
95 // Effect instantiation is deferred until the effect overscrolls, in which
96 // case the main thread may block until the resource has loaded.
97 if (enabled && g_overscroll_resources == NULL)
98 base::WorkerPool::PostTask(FROM_HERE, base::Bind(EnsureResources), true);
99
100 return make_scoped_ptr(new OverscrollGlow(enabled));
101 } 87 }
102 88
103 OverscrollGlow::OverscrollGlow(bool enabled)
104 : enabled_(enabled), initialized_(false) {}
105
106 OverscrollGlow::~OverscrollGlow() { 89 OverscrollGlow::~OverscrollGlow() {
107 Detach(); 90 Detach();
108 } 91 }
109 92
110 void OverscrollGlow::Enable() { 93 void OverscrollGlow::Enable() {
111 enabled_ = true; 94 enabled_ = true;
112 } 95 }
113 96
114 void OverscrollGlow::Disable() { 97 void OverscrollGlow::Disable() {
115 if (!enabled_) 98 if (!enabled_)
(...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after
215 if (!root_layer_) 198 if (!root_layer_)
216 return; 199 return;
217 200
218 if (!NeedsAnimate()) { 201 if (!NeedsAnimate()) {
219 Detach(); 202 Detach();
220 return; 203 return;
221 } 204 }
222 205
223 if (root_layer_->parent() != parent) 206 if (root_layer_->parent() != parent)
224 parent->AddChild(root_layer_); 207 parent->AddChild(root_layer_);
208
209 // Attempt to attach a valid resource Id to all subscribing layers. Must
210 // take place after layer attachment.
211 resource_manager_->RefreshResourceOnSubscribers(
powei 2014/07/12 00:24:47 this the hacky part. We need to call this to upda
jdduke (slow) 2014/07/12 01:01:09 Hmm, yeah I'll think about this.
212 ui::SystemUIResource::OVERSCROLL_EDGE);
213 resource_manager_->RefreshResourceOnSubscribers(
214 ui::SystemUIResource::OVERSCROLL_GLOW);
225 } 215 }
226 216
227 void OverscrollGlow::Detach() { 217 void OverscrollGlow::Detach() {
228 if (root_layer_) 218 if (root_layer_)
229 root_layer_->RemoveFromParent(); 219 root_layer_->RemoveFromParent();
230 } 220 }
231 221
232 bool OverscrollGlow::InitializeIfNecessary() { 222 bool OverscrollGlow::InitializeIfNecessary() {
233 DCHECK(enabled_); 223 DCHECK(enabled_);
234 if (initialized_) 224 if (initialized_)
235 return true; 225 return true;
236 226
237 const SkBitmap& edge = g_overscroll_resources.Get().edge_bitmap();
238 const SkBitmap& glow = g_overscroll_resources.Get().glow_bitmap();
239 if (edge.isNull() || glow.isNull()) {
240 Disable();
241 return false;
242 }
243
244 DCHECK(!root_layer_); 227 DCHECK(!root_layer_);
245 root_layer_ = cc::Layer::Create(); 228 root_layer_ = cc::Layer::Create();
246 for (size_t i = 0; i < EdgeEffect::EDGE_COUNT; ++i) { 229 for (size_t i = 0; i < EdgeEffect::EDGE_COUNT; ++i) {
247 scoped_refptr<cc::Layer> edge_layer = CreateImageLayer(edge); 230 scoped_ptr<OverscrollGlowLayer> edge_layer = OverscrollGlowLayer::Create(
248 scoped_refptr<cc::Layer> glow_layer = CreateImageLayer(glow); 231 ui::SystemUIResource::OVERSCROLL_EDGE, resource_manager_);
249 root_layer_->AddChild(edge_layer); 232 scoped_ptr<OverscrollGlowLayer> glow_layer = OverscrollGlowLayer::Create(
250 root_layer_->AddChild(glow_layer); 233 ui::SystemUIResource::OVERSCROLL_GLOW, resource_manager_);
251 edge_effects_[i] = make_scoped_ptr(new EdgeEffect(edge_layer, glow_layer)); 234 root_layer_->AddChild(edge_layer->layer());
235 root_layer_->AddChild(glow_layer->layer());
236 edge_effects_[i] = make_scoped_ptr(
237 new EdgeEffect(edge_layer.PassAs<OverscrollGlowLayerWrapper>(),
238 glow_layer.PassAs<OverscrollGlowLayerWrapper>()));
252 } 239 }
253 240
254 initialized_ = true; 241 initialized_ = true;
255 return true; 242 return true;
256 } 243 }
257 244
258 void OverscrollGlow::Pull(base::TimeTicks current_time, 245 void OverscrollGlow::Pull(base::TimeTicks current_time,
259 gfx::Vector2dF overscroll_delta) { 246 gfx::Vector2dF overscroll_delta) {
260 DCHECK(enabled_ && initialized_); 247 DCHECK(enabled_ && initialized_);
261 overscroll_delta = ZeroSmallComponents(overscroll_delta); 248 overscroll_delta = ZeroSmallComponents(overscroll_delta);
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after
331 DCHECK(initialized_); 318 DCHECK(initialized_);
332 return edge_effects_[(edge_index + 2) % EdgeEffect::EDGE_COUNT].get(); 319 return edge_effects_[(edge_index + 2) % EdgeEffect::EDGE_COUNT].get();
333 } 320 }
334 321
335 OverscrollGlow::DisplayParameters::DisplayParameters() 322 OverscrollGlow::DisplayParameters::DisplayParameters()
336 : device_scale_factor(1) { 323 : device_scale_factor(1) {
337 edge_offsets[0] = edge_offsets[1] = edge_offsets[2] = edge_offsets[3] = 0.f; 324 edge_offsets[0] = edge_offsets[1] = edge_offsets[2] = edge_offsets[3] = 0.f;
338 } 325 }
339 326
340 } // namespace content 327 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698