diff options
Diffstat (limited to 'platform/android/src/map/camera_position.cpp')
-rw-r--r-- | platform/android/src/map/camera_position.cpp | 24 |
1 files changed, 10 insertions, 14 deletions
diff --git a/platform/android/src/map/camera_position.cpp b/platform/android/src/map/camera_position.cpp index 01ffc6530b..5700341d65 100644 --- a/platform/android/src/map/camera_position.cpp +++ b/platform/android/src/map/camera_position.cpp @@ -5,7 +5,8 @@ namespace mbgl { namespace android { jni::Object<CameraPosition> CameraPosition::New(jni::JNIEnv &env, mbgl::CameraOptions options) { - static auto constructor = CameraPosition::javaClass.GetConstructor<jni::Object<LatLng>, double, double, double>(env); + static auto javaClass = jni::Class<CameraPosition>::Singleton(env); + static auto constructor = javaClass.GetConstructor<jni::Object<LatLng>, double, double, double>(env); // wrap LatLng values coming from core auto center = options.center.value(); @@ -24,18 +25,17 @@ jni::Object<CameraPosition> CameraPosition::New(jni::JNIEnv &env, mbgl::CameraOp // convert tilt, core ranges from [0 rad, 1,0472 rad], android ranges from 0 to 60 double tilt_degrees = options.pitch.value_or(0) * util::RAD2DEG; - return CameraPosition::javaClass.New(env, constructor, LatLng::New(env, center), options.zoom.value_or(0), tilt_degrees, bearing_degrees); + return javaClass.New(env, constructor, LatLng::New(env, center), options.zoom.value_or(0), tilt_degrees, bearing_degrees); } mbgl::CameraOptions CameraPosition::getCameraOptions(jni::JNIEnv& env, jni::Object<CameraPosition> position) { - static auto bearing = CameraPosition::javaClass.GetField<jni::jdouble>(env, "bearing"); - static auto target = CameraPosition::javaClass.GetField<jni::Object<LatLng>>(env, "target"); - static auto tilt = CameraPosition::javaClass.GetField<jni::jdouble>(env, "tilt"); - static auto zoom = CameraPosition::javaClass.GetField<jni::jdouble>(env, "zoom"); + static auto javaClass = jni::Class<CameraPosition>::Singleton(env); + static auto bearing = javaClass.GetField<jni::jdouble>(env, "bearing"); + static auto target = javaClass.GetField<jni::Object<LatLng>>(env, "target"); + static auto tilt = javaClass.GetField<jni::jdouble>(env, "tilt"); + static auto zoom = javaClass.GetField<jni::jdouble>(env, "zoom"); - auto jtarget = position.Get(env, target); - auto center = LatLng::getLatLng(env, jtarget); - jni::DeleteLocalRef(env, jtarget); + auto center = LatLng::getLatLng(env, *jni::SeizeLocal(env, position.Get(env, target))); return mbgl::CameraOptions { center, @@ -48,13 +48,9 @@ mbgl::CameraOptions CameraPosition::getCameraOptions(jni::JNIEnv& env, jni::Obje } void CameraPosition::registerNative(jni::JNIEnv &env) { - // Lookup the class - CameraPosition::javaClass = *jni::Class<CameraPosition>::Find(env).NewGlobalRef(env).release(); + jni::Class<CameraPosition>::Singleton(env); } -jni::Class<CameraPosition> CameraPosition::javaClass; - - } // namespace android } // namespace mb |