summaryrefslogtreecommitdiff
path: root/platform/android/src
diff options
context:
space:
mode:
authorPablo Guardiola <guardiola31337@gmail.com>2017-04-11 19:10:46 +0200
committerGitHub <noreply@github.com>2017-04-11 19:10:46 +0200
commitb71d86599d5e7c265b320300b18cfc0ea082c6d2 (patch)
treec5e45f36dc6fd4fcaaf57799a81b131805804913 /platform/android/src
parent1d33bf774f7d0248a72529840e155c4716a99851 (diff)
downloadqtlocation-mapboxgl-b71d86599d5e7c265b320300b18cfc0ea082c6d2.tar.gz
[android] Polygon holes (#8557)
* add 1 hole support to polygon-related classes * fix no hole crash and add triangle hole shape example * add support for multiple holes
Diffstat (limited to 'platform/android/src')
-rw-r--r--platform/android/src/annotation/polygon.cpp20
-rw-r--r--platform/android/src/annotation/polygon.hpp2
2 files changed, 21 insertions, 1 deletions
diff --git a/platform/android/src/annotation/polygon.cpp b/platform/android/src/annotation/polygon.cpp
index ba82fc34dc..fbd849432a 100644
--- a/platform/android/src/annotation/polygon.cpp
+++ b/platform/android/src/annotation/polygon.cpp
@@ -9,13 +9,26 @@ jni::Class<Polygon> Polygon::javaClass;
mbgl::FillAnnotation Polygon::toAnnotation(jni::JNIEnv& env, jni::Object<Polygon> polygon) {
auto points = Polygon::getPoints(env, polygon);
+ auto holes = Polygon::getHoles(env, polygon);
- mbgl::FillAnnotation annotation { mbgl::Polygon<double> { MultiPoint::toGeometry<mbgl::LinearRing<double>>(env, points) } };
+ mbgl::Polygon<double> geometry { MultiPoint::toGeometry<mbgl::LinearRing<double>>(env, points) };
+
+ auto jHoleListsArray = java::util::List::toArray<java::util::List>(env, holes);
+ std::size_t jHoleListsSize = jHoleListsArray.Length(env);
+ for (std::size_t i = 0; i < jHoleListsSize; i++) {
+ auto jHoleList = jHoleListsArray.Get(env, i);
+ geometry.push_back(MultiPoint::toGeometry<mbgl::LinearRing<double>>(env, jHoleList));
+ jni::DeleteLocalRef(env, jHoleList);
+ }
+ jni::DeleteLocalRef(env, jHoleListsArray);
+
+ mbgl::FillAnnotation annotation { geometry };
annotation.opacity = { Polygon::getOpacity(env, polygon) };
annotation.color = { Polygon::getFillColor(env, polygon) };
annotation.outlineColor = { Polygon::getOutlineColor(env, polygon) };
jni::DeleteLocalRef(env, points);
+ jni::DeleteLocalRef(env, holes);
return annotation;
}
@@ -25,6 +38,11 @@ jni::Object<java::util::List> Polygon::getPoints(jni::JNIEnv& env, jni::Object<P
return polygon.Get(env, field);
}
+jni::Object<java::util::List> Polygon::getHoles(jni::JNIEnv& env, jni::Object<Polygon> polygon) {
+ static auto field = Polygon::javaClass.GetField<jni::Object<java::util::List>>(env, "holes");
+ return polygon.Get(env, field);
+}
+
float Polygon::getOpacity(jni::JNIEnv& env, jni::Object<Polygon> polygon) {
static auto field = Polygon::javaClass.GetField<float>(env, "alpha");
return polygon.Get(env, field);
diff --git a/platform/android/src/annotation/polygon.hpp b/platform/android/src/annotation/polygon.hpp
index 658aa5344b..a98b2822cf 100644
--- a/platform/android/src/annotation/polygon.hpp
+++ b/platform/android/src/annotation/polygon.hpp
@@ -28,6 +28,8 @@ private:
static jni::Object<java::util::List> getPoints(jni::JNIEnv&, jni::Object<Polygon>);
+ static jni::Object<java::util::List> getHoles(jni::JNIEnv&, jni::Object<Polygon>);
+
static float getOpacity(jni::JNIEnv&, jni::Object<Polygon>);
static mbgl::Color getFillColor(jni::JNIEnv&, jni::Object<Polygon>);