#include "geometry.hpp" #include "point.hpp" #include "multi_point.hpp" #include "line_string.hpp" #include "multi_line_string.hpp" #include "polygon.hpp" #include "multi_polygon.hpp" #include "geometry_collection.hpp" #include namespace mbgl { namespace android { namespace geojson { /** * Turn mapbox::geometry type into Java GeoJson Geometries */ class GeometryEvaluator { public: jni::JNIEnv& env; jni::Object operator()(const mbgl::Point &geometry) const { return jni::Cast(env, Point::New(env, geometry), Geometry::javaClass); } jni::Object operator()(const mbgl::LineString &geometry) const { return jni::Cast(env, LineString::New(env, geometry), Geometry::javaClass); } jni::Object operator()(const mbgl::MultiLineString &geometry) const { return jni::Cast(env, MultiLineString::New(env, geometry), Geometry::javaClass); } jni::Object operator()(const mbgl::MultiPoint &geometry) const { return jni::Cast(env, MultiPoint::New(env, geometry), Geometry::javaClass); } jni::Object operator()(const mbgl::Polygon &geometry) const { return jni::Cast(env, Polygon::New(env, geometry), Geometry::javaClass); } jni::Object operator()(const mbgl::MultiPolygon &geometry) const { return jni::Cast(env, MultiPolygon::New(env, geometry), Geometry::javaClass); } jni::Object operator()(const mapbox::geometry::geometry_collection &geometry) const { return jni::Cast(env, GeometryCollection::New(env, geometry), Geometry::javaClass); } }; jni::Object Geometry::New(jni::JNIEnv& env, mbgl::Geometry geometry) { GeometryEvaluator evaluator { env } ; return mbgl::Geometry::visit(geometry, evaluator); } mbgl::Geometry Geometry::convert(jni::JNIEnv &env, jni::Object jGeometry) { auto type = Geometry::getType(env, jGeometry); if (type == Point::Type()) { return { Point::convert(env, jni::Object(jGeometry.Get())) }; } else if (type == MultiPoint::Type()) { return { MultiPoint::convert(env, jni::Object(jGeometry.Get())) }; } else if (type == LineString::Type()) { return { LineString::convert(env, jni::Object(jGeometry.Get())) }; } else if (type == MultiLineString::Type()) { return { MultiLineString::convert(env, jni::Object(jGeometry.Get())) }; } else if (type == Polygon::Type()) { return { Polygon::convert(env, jni::Object(jGeometry.Get())) }; } else if (type == MultiPolygon::Type()) { return { MultiPolygon::convert(env, jni::Object(jGeometry.Get())) }; } else if (type == GeometryCollection::Type()) { return { GeometryCollection::convert(env, jni::Object(jGeometry.Get())) }; } throw std::runtime_error(std::string {"Unsupported GeoJSON type: " } + type); } std::string Geometry::getType(jni::JNIEnv &env, jni::Object jGeometry) { static auto method = Geometry::javaClass.GetMethod(env, "type"); auto jType = jGeometry.Call(env, method); auto type = jni::Make(env, jType); jni::DeleteLocalRef(env, jType); return type; } void Geometry::registerNative(jni::JNIEnv &env) { // Lookup the class javaClass = *jni::Class::Find(env).NewGlobalRef(env).release(); } jni::Class Geometry::javaClass; } // namespace geojson } // namespace android } // namespace mbgl