summaryrefslogtreecommitdiff
path: root/platform/android/src/annotation/polyline.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'platform/android/src/annotation/polyline.cpp')
-rw-r--r--platform/android/src/annotation/polyline.cpp44
1 files changed, 13 insertions, 31 deletions
diff --git a/platform/android/src/annotation/polyline.cpp b/platform/android/src/annotation/polyline.cpp
index 3723dc1871..d6161e856e 100644
--- a/platform/android/src/annotation/polyline.cpp
+++ b/platform/android/src/annotation/polyline.cpp
@@ -5,45 +5,27 @@
namespace mbgl {
namespace android {
-jni::Class<Polyline> Polyline::javaClass;
+mbgl::LineAnnotation Polyline::toAnnotation(jni::JNIEnv& env, const jni::Object<Polyline>& polyline) {
+ static auto& javaClass = jni::Class<Polyline>::Singleton(env);
+ static auto points = javaClass.GetField<jni::Object<java::util::List>>(env, "points");
+ static auto alpha = javaClass.GetField<float>(env, "alpha");
+ static auto color = javaClass.GetField<int>(env, "color");
+ static auto width = javaClass.GetField<float>(env, "width");
-mbgl::LineAnnotation Polyline::toAnnotation(jni::JNIEnv& env, jni::Object<Polyline> polyline) {
- auto points = Polyline::getPoints(env, polyline);
+ mbgl::LineAnnotation annotation {
+ MultiPoint::toGeometry<mbgl::LineString<double>>(env, polyline.Get(env, points))
+ };
- mbgl::LineAnnotation annotation { MultiPoint::toGeometry<mbgl::LineString<double>>(env, points) };
- annotation.opacity = { Polyline::getOpacity(env, polyline) };
- annotation.color = { Polyline::getColor(env, polyline) };
- annotation.width = { Polyline::getWidth(env, polyline) };
-
- jni::DeleteLocalRef(env, points);
+ annotation.opacity = polyline.Get(env, alpha);
+ annotation.color = *conversion::convert<mbgl::Color>(env, polyline.Get(env, color));
+ annotation.width = polyline.Get(env, width);
return annotation;
}
-jni::Object<java::util::List> Polyline::getPoints(jni::JNIEnv& env, jni::Object<Polyline> polyline) {
- static auto field = Polyline::javaClass.GetField<jni::Object<java::util::List>>(env, "points");
- return polyline.Get(env, field);
-}
-
-float Polyline::getOpacity(jni::JNIEnv& env, jni::Object<Polyline> polyline) {
- static auto field = Polyline::javaClass.GetField<float>(env, "alpha");
- return polyline.Get(env, field);
-}
-
-mbgl::Color Polyline::getColor(jni::JNIEnv& env, jni::Object<Polyline> polyline) {
- static auto field = Polyline::javaClass.GetField<int>(env, "color");
- return *conversion::convert<mbgl::Color, int>(env, polyline.Get(env, field));
-}
-
-float Polyline::getWidth(jni::JNIEnv& env, jni::Object<Polyline> polyline) {
- static auto field = Polyline::javaClass.GetField<float>(env, "width");
- return polyline.Get(env, field);
-}
-
void Polyline::registerNative(jni::JNIEnv& env) {
- Polyline::javaClass = *jni::Class<Polyline>::Find(env).NewGlobalRef(env).release();
+ jni::Class<Polyline>::Singleton(env);
}
-
} // namespace android
} // namespace mbgl \ No newline at end of file