LBS相关工具函数
LBS相關工具函數
@(ML)[ML]
完整代碼請見:https://github.com/lujinhong/lujinhong-commons/tree/master/lujinhong-commons-java/src/main/java/com/lujinhong/commons/java/lbs
1、計算某個點周圍一定距離的經緯度范圍
public static Map<String, Double> getAround(Double latitude, Double longitude, Double raidusMile) {HashMap<String, Double> map = new HashMap();Double degree = (24901 * 1609) / 360.0; // 獲取每度Double mpdLng = Double.parseDouble((degree * Math.cos(latitude * (Math.PI / 180))+"").replace("-", ""));Double dpmLng = 1 / mpdLng;Double radiusLng = dpmLng * raidusMile;//獲取最小經度Double minLng = longitude - radiusLng;// 獲取最大經度Double maxLng = longitude + radiusLng;Double dpmLat = 1 / degree;Double radiusLat = dpmLat * raidusMile;// 獲取最小緯度Double minLat = latitude - radiusLat;// 獲取最大緯度Double maxLat = latitude + radiusLat;map.put("minLat", minLat);map.put("maxLat", maxLat);map.put("minLng", minLng);map.put("maxLng", maxLng);return map; }2、計算2個經緯度點之間的距離,單位為米
public static double getDistance(double lng1, double lat1, double lng2,double lat2) {double a, b, R;R = 6378137; // 地球半徑lat1 = lat1 * Math.PI / 180.0;lat2 = lat2 * Math.PI / 180.0;a = lat1 - lat2;b = (lng1 - lng2) * Math.PI / 180.0;double d;double sa2, sb2;sa2 = Math.sin(a / 2.0);sb2 = Math.sin(b / 2.0);d = 2 * R * Math.asin(Math.sqrt(sa2 * sa2 + Math.cos(lat1) * Math.cos(lat2) * sb2 * sb2));return d; }總結
- 上一篇: 关于LBS坐标系与精度的问题
- 下一篇: solr文档索引最佳实践