OLD | NEW |
---|---|
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 Loading... | |
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 Loading... | |
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 |
OLD | NEW |