summaryrefslogtreecommitdiff
path: root/platform/android/src/text/local_glyph_rasterizer.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'platform/android/src/text/local_glyph_rasterizer.cpp')
-rw-r--r--platform/android/src/text/local_glyph_rasterizer.cpp29
1 files changed, 11 insertions, 18 deletions
diff --git a/platform/android/src/text/local_glyph_rasterizer.cpp b/platform/android/src/text/local_glyph_rasterizer.cpp
index 3dc1eb275a..8892ee3f37 100644
--- a/platform/android/src/text/local_glyph_rasterizer.cpp
+++ b/platform/android/src/text/local_glyph_rasterizer.cpp
@@ -36,37 +36,30 @@ namespace android {
LocalGlyphRasterizer::LocalGlyphRasterizer() {
UniqueEnv env { AttachEnv() };
+ static auto& javaClass = jni::Class<LocalGlyphRasterizer>::Singleton(*env);
static auto constructor = javaClass.GetConstructor(*env);
- javaObject = javaClass.New(*env, constructor).NewGlobalRef(*env);
+ javaObject = jni::NewGlobal(*env, javaClass.New(*env, constructor));
}
PremultipliedImage LocalGlyphRasterizer::drawGlyphBitmap(const std::string& fontFamily, const bool bold, const GlyphID glyphID) {
UniqueEnv env { AttachEnv() };
- using Signature = jni::Object<Bitmap>(jni::String, jni::jboolean, jni::jchar);
- static auto method = javaClass.GetMethod<Signature>(*env, "drawGlyphBitmap");
+ static auto& javaClass = jni::Class<LocalGlyphRasterizer>::Singleton(*env);
+ static auto drawGlyphBitmap = javaClass.GetMethod<jni::Object<Bitmap> (jni::String, jni::jboolean, jni::jchar)>(*env, "drawGlyphBitmap");
- jni::String jniFontFamily = jni::Make<jni::String>(*env, fontFamily);
-
- auto javaBitmap = javaObject->Call(*env,
- method,
- jniFontFamily,
- static_cast<jni::jboolean>(bold),
- static_cast<jni::jchar>(glyphID));
- jni::DeleteLocalRef(*env, jniFontFamily);
-
- PremultipliedImage result = Bitmap::GetImage(*env, javaBitmap);
- jni::DeleteLocalRef(*env, javaBitmap);
- return result;
+ return Bitmap::GetImage(*env,
+ javaObject.Call(*env,
+ drawGlyphBitmap,
+ jni::Make<jni::String>(*env, fontFamily),
+ static_cast<jni::jboolean>(bold),
+ static_cast<jni::jchar>(glyphID)));
}
void LocalGlyphRasterizer::registerNative(jni::JNIEnv& env) {
- javaClass = *jni::Class<LocalGlyphRasterizer>::Find(env).NewGlobalRef(env).release();
+ jni::Class<LocalGlyphRasterizer>::Singleton(env);
}
-jni::Class<LocalGlyphRasterizer> LocalGlyphRasterizer::javaClass;
-
} // namespace android
class LocalGlyphRasterizer::Impl {