#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 Point::New(env, geometry); } jni::Object operator()(const mbgl::LineString &geometry) const { return LineString::New(env, geometry); } jni::Object operator()(const mbgl::MultiLineString &geometry) const { return MultiLineString::New(env, geometry); } jni::Object operator()(const mbgl::MultiPoint &geometry) const { return MultiPoint::New(env, geometry); } jni::Object operator()(const mbgl::Polygon &geometry) const { return Polygon::New(env, geometry); } jni::Object operator()(const mbgl::MultiPolygon &geometry) const { return MultiPolygon::New(env, geometry); } jni::Object operator()(const mapbox::geometry::geometry_collection &geometry) const { return GeometryCollection::New(env, geometry); } }; 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 javaClass = jni::Class::Singleton(env); static auto method = javaClass.GetMethod(env, "type"); return jni::Make(env, *jni::SeizeLocal(env, jGeometry.Call(env, method))); } void Geometry::registerNative(jni::JNIEnv &env) { jni::Class::Singleton(env); } } // namespace geojson } // namespace android } // namespace mbgl