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

Side by Side Diff: ui/gfx/android/java_bitmap.cc

Issue 22870016: Update the nine patch layer to use UI resources (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: updated comments to reflect changes Created 7 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
« ui/gfx/android/java_bitmap.h ('K') | « ui/gfx/android/java_bitmap.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 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 "ui/gfx/android/java_bitmap.h" 5 #include "ui/gfx/android/java_bitmap.h"
6 6
7 #include <android/bitmap.h> 7 #include <android/bitmap.h>
8 8
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "jni/BitmapHelper_jni.h" 10 #include "jni/BitmapHelper_jni.h"
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
54 CreateJavaBitmap(gfx::Size(skbitmap->width(), skbitmap->height())); 54 CreateJavaBitmap(gfx::Size(skbitmap->width(), skbitmap->height()));
55 SkAutoLockPixels src_lock(*skbitmap); 55 SkAutoLockPixels src_lock(*skbitmap);
56 JavaBitmap dst_lock(jbitmap.obj()); 56 JavaBitmap dst_lock(jbitmap.obj());
57 void* src_pixels = skbitmap->getPixels(); 57 void* src_pixels = skbitmap->getPixels();
58 void* dst_pixels = dst_lock.pixels(); 58 void* dst_pixels = dst_lock.pixels();
59 memcpy(dst_pixels, src_pixels, skbitmap->getSize()); 59 memcpy(dst_pixels, src_pixels, skbitmap->getSize());
60 60
61 return jbitmap; 61 return jbitmap;
62 } 62 }
63 63
64 static ScopedJavaLocalRef<jobject> CreateJavaBitmapFromResource( 64 SkBitmap CreateSkBitmapFromJavaBitmap(JavaBitmap& jbitmap) {
65 const char* name, gfx::Size requested_size) { 65 DCHECK_EQ(jbitmap.format(), ANDROID_BITMAP_FORMAT_RGBA_8888);
66 JNIEnv* env = AttachCurrentThread();
67 ScopedJavaLocalRef<jstring> jname(env, env->NewStringUTF(name));
68 return ui::Java_BitmapHelper_decodeDrawableResource(env,
69 jname.obj(),
70 requested_size.width(),
71 requested_size.height());
72 }
73 66
74 static SkBitmap ConvertToSkBitmap(ScopedJavaLocalRef<jobject> jbitmap) { 67 gfx::Size src_size = jbitmap.size();
75 if (jbitmap.is_null())
76 return SkBitmap();
77
78 JavaBitmap src_lock(jbitmap.obj());
79 DCHECK_EQ(src_lock.format(), ANDROID_BITMAP_FORMAT_RGBA_8888);
80
81 gfx::Size src_size = src_lock.size();
82 68
83 SkBitmap skbitmap; 69 SkBitmap skbitmap;
84 skbitmap.setConfig(SkBitmap::kARGB_8888_Config, 70 skbitmap.setConfig(SkBitmap::kARGB_8888_Config,
85 src_size.width(), src_size.height(), src_lock.stride()); 71 src_size.width(),
72 src_size.height(),
73 jbitmap.stride());
86 skbitmap.allocPixels(); 74 skbitmap.allocPixels();
87 SkAutoLockPixels dst_lock(skbitmap); 75 SkAutoLockPixels dst_lock(skbitmap);
88 76
89 void* src_pixels = src_lock.pixels(); 77 void* src_pixels = jbitmap.pixels();
90 void* dst_pixels = skbitmap.getPixels(); 78 void* dst_pixels = skbitmap.getPixels();
91 79
92 memcpy(dst_pixels, src_pixels, skbitmap.getSize()); 80 memcpy(dst_pixels, src_pixels, skbitmap.getSize());
93 81
94 return skbitmap; 82 return skbitmap;
95 } 83 }
96 84
97 SkBitmap CreateSkBitmapFromResource(const char* name, gfx::Size size) { 85 SkBitmap CreateSkBitmapFromResource(const char* name, gfx::Size size) {
98 DCHECK(!size.IsEmpty()); 86 DCHECK(!size.IsEmpty());
99 SkBitmap bitmap = 87 JNIEnv* env = AttachCurrentThread();
100 ConvertToSkBitmap(CreateJavaBitmapFromResource(name, size)); 88 ScopedJavaLocalRef<jstring> jname(env, env->NewStringUTF(name));
101 if (bitmap.isNull()) 89 ScopedJavaLocalRef<jobject> jobj(ui::Java_BitmapHelper_decodeDrawableResource(
102 return bitmap; 90 env, jname.obj(), size.width(), size.height()));
103 // RESIZE_BOX has sufficient downsampling quality with minimal runtime cost. 91 if (jobj.is_null())
104 return skia::ImageOperations::Resize(bitmap, 92 return SkBitmap();
105 skia::ImageOperations::RESIZE_BOX, 93
106 size.width(), size.height()); 94 JavaBitmap jbitmap(jobj.obj());
95 SkBitmap bitmap = CreateSkBitmapFromJavaBitmap(jbitmap);
Yaron 2013/09/10 00:28:39 You dropped the SkBitmap null-check. Intentional?
powei 2013/09/10 00:42:44 yes, in the old code, bitmap.isNull() is true when
96 return skia::ImageOperations::Resize(
97 bitmap, skia::ImageOperations::RESIZE_BOX, size.width(), size.height());
107 } 98 }
108 99
109 } // namespace gfx 100 } // namespace gfx
OLDNEW
« ui/gfx/android/java_bitmap.h ('K') | « ui/gfx/android/java_bitmap.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698