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 184453002: Android::Pass Bitmap.Config instead of bool to CreateJavaBitmap (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Pass Bitmap.Config instead of bool to CreateJavaBitmap Created 6 years, 9 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/android/jni_string.h" 9 #include "base/android/jni_string.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
(...skipping 23 matching lines...) Expand all
34 JavaBitmap::~JavaBitmap() { 34 JavaBitmap::~JavaBitmap() {
35 int err = AndroidBitmap_unlockPixels(AttachCurrentThread(), bitmap_); 35 int err = AndroidBitmap_unlockPixels(AttachCurrentThread(), bitmap_);
36 DCHECK(!err); 36 DCHECK(!err);
37 } 37 }
38 38
39 // static 39 // static
40 bool JavaBitmap::RegisterJavaBitmap(JNIEnv* env) { 40 bool JavaBitmap::RegisterJavaBitmap(JNIEnv* env) {
41 return RegisterNativesImpl(env); 41 return RegisterNativesImpl(env);
42 } 42 }
43 43
44 static ScopedJavaLocalRef<jobject> CreateJavaBitmap(int width, int height, 44 static ScopedJavaLocalRef<jobject> CreateJavaBitmap(int width,
45 bool is565_config) { 45 int height,
46 return Java_BitmapHelper_createBitmap(AttachCurrentThread(), 46 jobject bitmap_config) {
bulach 2014/02/28 13:19:25 ditto, just pass the int through instead of the jo
sivag 2014/03/04 12:36:04 Done.
47 width, height, is565_config); 47
48 return Java_BitmapHelper_createBitmap(
49 AttachCurrentThread(), width, height, bitmap_config);
48 } 50 }
49 51
50 ScopedJavaLocalRef<jobject> ConvertToJavaBitmap(const SkBitmap* skbitmap) { 52 ScopedJavaLocalRef<jobject> ConvertToJavaBitmap(const SkBitmap* skbitmap) {
51 DCHECK(skbitmap); 53 DCHECK(skbitmap);
52 SkBitmap::Config config = skbitmap->getConfig(); 54 SkBitmap::Config config = skbitmap->getConfig();
53 DCHECK((config == SkBitmap::kRGB_565_Config) || 55 DCHECK((config == SkBitmap::kRGB_565_Config) ||
54 (config == SkBitmap::kARGB_8888_Config)); 56 (config == SkBitmap::kARGB_8888_Config));
55 // If the Config is not RGB565 it is default i.e ARGB8888 57 // If the Config is not RGB565 it is default i.e ARGB8888
56 ScopedJavaLocalRef<jobject> jbitmap = 58 ScopedJavaLocalRef<jobject> java_bitmap_config =
57 CreateJavaBitmap(skbitmap->width(), skbitmap->height(), 59 ConvertToJavaBitmapConfig(config);
58 (config == SkBitmap::kRGB_565_Config)); 60 ScopedJavaLocalRef<jobject> jbitmap = CreateJavaBitmap(
61 skbitmap->width(), skbitmap->height(), java_bitmap_config.obj());
59 SkAutoLockPixels src_lock(*skbitmap); 62 SkAutoLockPixels src_lock(*skbitmap);
60 JavaBitmap dst_lock(jbitmap.obj()); 63 JavaBitmap dst_lock(jbitmap.obj());
61 void* src_pixels = skbitmap->getPixels(); 64 void* src_pixels = skbitmap->getPixels();
62 void* dst_pixels = dst_lock.pixels(); 65 void* dst_pixels = dst_lock.pixels();
63 memcpy(dst_pixels, src_pixels, skbitmap->getSize()); 66 memcpy(dst_pixels, src_pixels, skbitmap->getSize());
64 67
65 return jbitmap; 68 return jbitmap;
66 } 69 }
67 70
68 SkBitmap CreateSkBitmapFromJavaBitmap(JavaBitmap& jbitmap) { 71 SkBitmap CreateSkBitmapFromJavaBitmap(JavaBitmap& jbitmap) {
(...skipping 26 matching lines...) Expand all
95 if (jobj.is_null()) 98 if (jobj.is_null())
96 return SkBitmap(); 99 return SkBitmap();
97 100
98 JavaBitmap jbitmap(jobj.obj()); 101 JavaBitmap jbitmap(jobj.obj());
99 SkBitmap bitmap = CreateSkBitmapFromJavaBitmap(jbitmap); 102 SkBitmap bitmap = CreateSkBitmapFromJavaBitmap(jbitmap);
100 return skia::ImageOperations::Resize( 103 return skia::ImageOperations::Resize(
101 bitmap, skia::ImageOperations::RESIZE_BOX, size.width(), size.height()); 104 bitmap, skia::ImageOperations::RESIZE_BOX, size.width(), size.height());
102 } 105 }
103 106
104 SkBitmap::Config ConvertToSkiaConfig(jobject bitmap_config) { 107 SkBitmap::Config ConvertToSkiaConfig(jobject bitmap_config) {
105 int jbitmap_config = 108 int jbitmap_config = Java_BitmapHelper_getConfigEnumValue(
106 Java_BitmapHelper_bitmapConfig(AttachCurrentThread(), bitmap_config); 109 AttachCurrentThread(), bitmap_config);
107 switch (jbitmap_config) { 110 switch (jbitmap_config) {
108 case BITMAP_FORMAT_ALPHA_8: 111 case BITMAP_FORMAT_ALPHA_8:
109 return SkBitmap::kA8_Config; 112 return SkBitmap::kA8_Config;
110 case BITMAP_FORMAT_ARGB_4444: 113 case BITMAP_FORMAT_ARGB_4444:
111 return SkBitmap::kARGB_4444_Config; 114 return SkBitmap::kARGB_4444_Config;
112 case BITMAP_FORMAT_ARGB_8888: 115 case BITMAP_FORMAT_ARGB_8888:
113 return SkBitmap::kARGB_8888_Config; 116 return SkBitmap::kARGB_8888_Config;
114 case BITMAP_FORMAT_RGB_565: 117 case BITMAP_FORMAT_RGB_565:
115 return SkBitmap::kRGB_565_Config; 118 return SkBitmap::kRGB_565_Config;
116 case BITMAP_FORMAT_NO_CONFIG: 119 case BITMAP_FORMAT_NO_CONFIG:
117 default: 120 default:
118 return SkBitmap::kNo_Config; 121 return SkBitmap::kNo_Config;
119 } 122 }
120 } 123 }
121 124
125 ScopedJavaLocalRef<jobject> ConvertToJavaBitmapConfig(
bulach 2014/02/28 13:19:25 nit: perhaps SkBitmapConfigToBitmapFormat ? ...mak
jdduke (slow) 2014/02/28 14:20:59 +1 to passing an int and removing the additional J
sivag 2014/03/04 12:36:04 Done.
sivag 2014/03/04 12:36:04 Done.
126 SkBitmap::Config bitmap_config) {
127 int matching_enum_config = BITMAP_FORMAT_NO_CONFIG;
128 switch (bitmap_config) {
129 case SkBitmap::kA8_Config:
130 matching_enum_config = BITMAP_FORMAT_ALPHA_8;
131 break;
132 case SkBitmap::kARGB_4444_Config:
133 matching_enum_config = BITMAP_FORMAT_ARGB_4444;
134 break;
135 case SkBitmap::kARGB_8888_Config:
136 matching_enum_config = BITMAP_FORMAT_ARGB_8888;
137 break;
138 case SkBitmap::kRGB_565_Config:
139 matching_enum_config = BITMAP_FORMAT_RGB_565;
140 break;
141 case SkBitmap::kNo_Config:
142 default:
143 matching_enum_config = BITMAP_FORMAT_NO_CONFIG;
144 break;
145 }
146 DCHECK(matching_enum_config == BITMAP_FORMAT_NO_CONFIG);
147 return Java_BitmapHelper_getJavabitmapConfig(AttachCurrentThread(),
148 matching_enum_config);
149 }
150
122 } // namespace gfx 151 } // 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