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

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

Issue 454863003: Revert of [Android] Use UIResource for overscroll glow (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 4 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 "cc/layers/layer.h" 9 #include "base/threading/worker_pool.h"
10 #include "cc/layers/image_layer.h"
10 #include "content/browser/android/edge_effect.h" 11 #include "content/browser/android/edge_effect.h"
12 #include "skia/ext/image_operations.h"
13 #include "ui/gfx/android/java_bitmap.h"
11 14
12 using std::max; 15 using std::max;
13 using std::min; 16 using std::min;
14 17
15 namespace content { 18 namespace content {
16 19
17 namespace { 20 namespace {
18 21
19 const float kEpsilon = 1e-3f; 22 const float kEpsilon = 1e-3f;
23 const int kScaledEdgeHeight = 12;
24 const int kScaledGlowHeight = 64;
20 const float kEdgeHeightAtMdpi = 12.f; 25 const float kEdgeHeightAtMdpi = 12.f;
21 const float kGlowHeightAtMdpi = 128.f; 26 const float kGlowHeightAtMdpi = 128.f;
22 27
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
23 bool IsApproxZero(float value) { 74 bool IsApproxZero(float value) {
24 return std::abs(value) < kEpsilon; 75 return std::abs(value) < kEpsilon;
25 } 76 }
26 77
27 gfx::Vector2dF ZeroSmallComponents(gfx::Vector2dF vector) { 78 gfx::Vector2dF ZeroSmallComponents(gfx::Vector2dF vector) {
28 if (IsApproxZero(vector.x())) 79 if (IsApproxZero(vector.x()))
29 vector.set_x(0); 80 vector.set_x(0);
30 if (IsApproxZero(vector.y())) 81 if (IsApproxZero(vector.y()))
31 vector.set_y(0); 82 vector.set_y(0);
32 return vector; 83 return vector;
33 } 84 }
34 85
35 } // namespace 86 // Force loading of any necessary resources. This function is thread-safe.
36 87 void EnsureResources() {
37 scoped_ptr<OverscrollGlow> OverscrollGlow::Create( 88 g_overscroll_resources.Get();
38 ui::SystemUIResourceManager* resource_manager) {
39 return make_scoped_ptr(new OverscrollGlow(resource_manager));
40 } 89 }
41 90
42 OverscrollGlow::OverscrollGlow(ui::SystemUIResourceManager* resource_manager) 91 } // namespace
43 : enabled_(true), initialized_(false), resource_manager_(resource_manager) { 92
44 DCHECK(resource_manager_); 93 scoped_ptr<OverscrollGlow> OverscrollGlow::Create(bool enabled) {
45 EdgeEffect::PreloadResources(resource_manager_); 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));
46 } 101 }
47 102
103 OverscrollGlow::OverscrollGlow(bool enabled)
104 : enabled_(enabled), initialized_(false) {}
105
48 OverscrollGlow::~OverscrollGlow() { 106 OverscrollGlow::~OverscrollGlow() {
49 Detach(); 107 Detach();
50 } 108 }
51 109
52 void OverscrollGlow::Enable() { 110 void OverscrollGlow::Enable() {
53 enabled_ = true; 111 enabled_ = true;
54 } 112 }
55 113
56 void OverscrollGlow::Disable() { 114 void OverscrollGlow::Disable() {
57 if (!enabled_) 115 if (!enabled_)
(...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after
157 if (!root_layer_) 215 if (!root_layer_)
158 return; 216 return;
159 217
160 if (!NeedsAnimate()) { 218 if (!NeedsAnimate()) {
161 Detach(); 219 Detach();
162 return; 220 return;
163 } 221 }
164 222
165 if (root_layer_->parent() != parent) 223 if (root_layer_->parent() != parent)
166 parent->AddChild(root_layer_); 224 parent->AddChild(root_layer_);
167
168 for (size_t i = 0; i < EdgeEffect::EDGE_COUNT; ++i)
169 edge_effects_[i]->SetParent(root_layer_);
170 } 225 }
171 226
172 void OverscrollGlow::Detach() { 227 void OverscrollGlow::Detach() {
173 if (root_layer_) 228 if (root_layer_)
174 root_layer_->RemoveFromParent(); 229 root_layer_->RemoveFromParent();
175 } 230 }
176 231
177 bool OverscrollGlow::InitializeIfNecessary() { 232 bool OverscrollGlow::InitializeIfNecessary() {
178 DCHECK(enabled_); 233 DCHECK(enabled_);
179 if (initialized_) 234 if (initialized_)
180 return true; 235 return true;
181 236
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
182 DCHECK(!root_layer_); 244 DCHECK(!root_layer_);
183 root_layer_ = cc::Layer::Create(); 245 root_layer_ = cc::Layer::Create();
184 for (size_t i = 0; i < EdgeEffect::EDGE_COUNT; ++i) 246 for (size_t i = 0; i < EdgeEffect::EDGE_COUNT; ++i) {
185 edge_effects_[i] = make_scoped_ptr(new EdgeEffect(resource_manager_)); 247 scoped_refptr<cc::Layer> edge_layer = CreateImageLayer(edge);
248 scoped_refptr<cc::Layer> glow_layer = CreateImageLayer(glow);
249 root_layer_->AddChild(edge_layer);
250 root_layer_->AddChild(glow_layer);
251 edge_effects_[i] = make_scoped_ptr(new EdgeEffect(edge_layer, glow_layer));
252 }
186 253
187 initialized_ = true; 254 initialized_ = true;
188 return true; 255 return true;
189 } 256 }
190 257
191 void OverscrollGlow::Pull(base::TimeTicks current_time, 258 void OverscrollGlow::Pull(base::TimeTicks current_time,
192 gfx::Vector2dF overscroll_delta) { 259 gfx::Vector2dF overscroll_delta) {
193 DCHECK(enabled_ && initialized_); 260 DCHECK(enabled_ && initialized_);
194 overscroll_delta = ZeroSmallComponents(overscroll_delta); 261 overscroll_delta = ZeroSmallComponents(overscroll_delta);
195 if (overscroll_delta.IsZero()) 262 if (overscroll_delta.IsZero())
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after
264 DCHECK(initialized_); 331 DCHECK(initialized_);
265 return edge_effects_[(edge_index + 2) % EdgeEffect::EDGE_COUNT].get(); 332 return edge_effects_[(edge_index + 2) % EdgeEffect::EDGE_COUNT].get();
266 } 333 }
267 334
268 OverscrollGlow::DisplayParameters::DisplayParameters() 335 OverscrollGlow::DisplayParameters::DisplayParameters()
269 : device_scale_factor(1) { 336 : device_scale_factor(1) {
270 edge_offsets[0] = edge_offsets[1] = edge_offsets[2] = edge_offsets[3] = 0.f; 337 edge_offsets[0] = edge_offsets[1] = edge_offsets[2] = edge_offsets[3] = 0.f;
271 } 338 }
272 339
273 } // namespace content 340 } // namespace content
OLDNEW
« no previous file with comments | « content/browser/android/overscroll_glow.h ('k') | content/browser/android/system_ui_resource_manager_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698