Chromium Code Reviews| 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 |