From 27ddbb9b69949b74e359b7f8ad9204ea87232706 Mon Sep 17 00:00:00 2001 From: Igor Tarasov Date: Thu, 2 Apr 2020 12:08:01 +0300 Subject: [android] [build] [ci] Move Android JNI bindings code to mapbox-gl-native-android repo. --- platform/android/src/map/camera_position.cpp | 69 ---------------------------- 1 file changed, 69 deletions(-) delete mode 100644 platform/android/src/map/camera_position.cpp (limited to 'platform/android/src/map/camera_position.cpp') diff --git a/platform/android/src/map/camera_position.cpp b/platform/android/src/map/camera_position.cpp deleted file mode 100644 index 4266b64fdf..0000000000 --- a/platform/android/src/map/camera_position.cpp +++ /dev/null @@ -1,69 +0,0 @@ -#include "camera_position.hpp" -#include "../geometry/lat_lng.hpp" - -namespace mbgl { -namespace android { - -jni::Local> CameraPosition::New(jni::JNIEnv &env, mbgl::CameraOptions options, float pixelRatio) { - static auto& javaClass = jni::Class::Singleton(env); - static auto constructor = javaClass.GetConstructor, double, double, double, jni::Array>(env); - - // wrap LatLng values coming from core - auto center = options.center.value(); - center.wrap(); - - // convert bearing, measured in radians counterclockwise from true north. - // Wrapped to [−π rad, π rad). Android binding from 0 to 360 degrees - double bearing_degrees = options.bearing.value_or(0); - while (bearing_degrees > 360) { - bearing_degrees -= 360; - } - while (bearing_degrees < 0) { - bearing_degrees += 360; - } - - // convert tilt, core ranges from [0 rad, 1,0472 rad], android ranges from 0 to 60 - double tilt_degrees = options.pitch.value_or(0); - - std::vector paddingVect; - auto insets = options.padding.value_or(EdgeInsets {0, 0, 0, 0}); - auto padding = jni::Array::New(env, 4); - paddingVect.push_back(insets.left() * pixelRatio); - paddingVect.push_back(insets.top() * pixelRatio); - paddingVect.push_back(insets.right() * pixelRatio); - paddingVect.push_back(insets.bottom() * pixelRatio); - padding.SetRegion>(env, 0, paddingVect); - - return javaClass.New(env, constructor, LatLng::New(env, center), options.zoom.value_or(0), tilt_degrees, bearing_degrees, padding); -} - -mbgl::CameraOptions CameraPosition::getCameraOptions(jni::JNIEnv& env, const jni::Object& position, float pixelRatio) { - static auto& javaClass = jni::Class::Singleton(env); - static auto bearing = javaClass.GetField(env, "bearing"); - static auto target = javaClass.GetField>(env, "target"); - static auto tilt = javaClass.GetField(env, "tilt"); - static auto zoom = javaClass.GetField(env, "zoom"); - static auto paddingField = javaClass.GetField>(env, "padding"); - - auto padding = position.Get(env, paddingField); - auto center = LatLng::getLatLng(env, position.Get(env, target)); - - return mbgl::CameraOptions{center, - padding && padding.Length(env) == 4 ? EdgeInsets{padding.Get(env, 1) * pixelRatio, - padding.Get(env, 0) * pixelRatio, - padding.Get(env, 3) * pixelRatio, - padding.Get(env, 2) * pixelRatio} - : (EdgeInsets){}, - {}, - position.Get(env, zoom), - position.Get(env, bearing), - position.Get(env, tilt)}; -} - -void CameraPosition::registerNative(jni::JNIEnv &env) { - jni::Class::Singleton(env); -} - -} // namespace android -} // namespace mb - -- cgit v1.2.1