如何在 Android Studio 中添加捕捉到道路 Google 地图
How to Add Snap to Roads Google Map in Android Studio
你好我想问一下当我有google地图API给出的路线时如何添加Snap to Road。
我有一堆从 A 点线到 B 点线的 Lat lang 并画了一条像折线一样的线,但我想要的是如何从给定路线将此代码捕捉添加到 Road?
这是从 A 点到 B 点添加更多点的方法,
这是我想补充的,
https://developers.google.com/maps/documentation/roads/snap
我的项目是这样的
- 通过Json和Gson获取overview_polyline(应使用https://maps.googleapis.com/maps/api/directions/json?origin=...&destination=place_id:...&mode=DRIVING&key=..。)
按函数解码成List
public List<LatLng> decodePoly(String encoded) {
// encoded is overview_polyline.points;
List<LatLng> poly = new ArrayList<LatLng>();
int index = 0, len = encoded.length();
int lat = 0, lng = 0;
while (index < len) {
int b, shift = 0, result = 0;
do {
b = encoded.charAt(index++) - 63;
result |= (b & 0x1f) << shift;
shift += 5;
} while (b >= 0x20);
int dlat = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1));
lat += dlat;
shift = 0;
result = 0;
do {
b = encoded.charAt(index++) - 63;
result |= (b & 0x1f) << shift;
shift += 5;
} while (b >= 0x20);
int dlng = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1));
lng += dlng;
LatLng p = new LatLng((((double) lat / 1E5)),
(((double) lng / 1E5)));
poly.add(p);
}
return poly;
}
3.Add 映射:
PolylineOptions polylineOptions= new PolylineOptions();
polylineOptions.addAll(decodePoly(overview_polyline.points));
mGoogleMap.addPolyline(polylineOptions.width(5).color(Color.BLUE).geodesic(false));
你好我想问一下当我有google地图API给出的路线时如何添加Snap to Road。 我有一堆从 A 点线到 B 点线的 Lat lang 并画了一条像折线一样的线,但我想要的是如何从给定路线将此代码捕捉添加到 Road? 这是从 A 点到 B 点添加更多点的方法, 这是我想补充的, https://developers.google.com/maps/documentation/roads/snap
我的项目是这样的
- 通过Json和Gson获取overview_polyline(应使用https://maps.googleapis.com/maps/api/directions/json?origin=...&destination=place_id:...&mode=DRIVING&key=..。)
按函数解码成List
public List<LatLng> decodePoly(String encoded) { // encoded is overview_polyline.points; List<LatLng> poly = new ArrayList<LatLng>(); int index = 0, len = encoded.length(); int lat = 0, lng = 0; while (index < len) { int b, shift = 0, result = 0; do { b = encoded.charAt(index++) - 63; result |= (b & 0x1f) << shift; shift += 5; } while (b >= 0x20); int dlat = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1)); lat += dlat; shift = 0; result = 0; do { b = encoded.charAt(index++) - 63; result |= (b & 0x1f) << shift; shift += 5; } while (b >= 0x20); int dlng = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1)); lng += dlng; LatLng p = new LatLng((((double) lat / 1E5)), (((double) lng / 1E5))); poly.add(p); } return poly; }
3.Add 映射:
PolylineOptions polylineOptions= new PolylineOptions(); polylineOptions.addAll(decodePoly(overview_polyline.points)); mGoogleMap.addPolyline(polylineOptions.width(5).color(Color.BLUE).geodesic(false));