/** * 根据两个位置的经纬度,来计算两地的距离(单位为KM) * 参数为String类型 * @param lng1Str 起点经度 * @param lng1Str 起点纬度 * @param lat2Str 终点经度 * @param lng2Str 终点纬度 * @return */ public static Double getDistance(String lat1Str, String lng1Str, String lat2Str, String lng2Str) { Double lat1 = Double.parseDouble(lat1Str); Double lng1 = Double.parseDouble(lng1Str); Double lat2 = Double.parseDouble(lat2Str); Double lng2 = Double.parseDouble(lng2Str); double radLat1 = rad(lat1); double radLat2 = rad(lat2); double difference = radLat1 - radLat2; double mdifference = rad(lng1) - rad(lng2); double distance = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(difference / 2), 2) + Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(mdifference / 2), 2))); distance = distance * EARTH_RADIUS; distance = Math.round(distance * 10000) / 10000; /* String distanceStr = distance+""; distanceStr = distanceStr. substring(0, distanceStr.indexOf("."));*/ return distance; } private static double rad(double d) { return d * Math.PI / 180.0; } private static double EARTH_RADIUS = 6378.137;
根据两个位置的经纬度,来计算两地的距离(记录下来,说不定下次还要用)
最新推荐文章于 2023-08-29 17:14:43 发布