代码:
import java.math.BigDecimal;
/**
* @Auther: sss
* @Date: 2020/7/23 13:53
* @Description:
*/
public class DistanceTest {
private final static double EARTH_RADIUS = 6378.137;//地球半径
private static double rad(double d) {
return d * Math.PI / 180.0;
}
/**
* 计算国内坐标系两点间距离 (高德地图)
*
* @return double 距离 单位公里,精确到米
*/
public static double GetDistance(double lat1, double lng1, double lat2, double lng2) {
double radLat1 = rad(lat1);
double radLat2 = rad(lat2);
double a = radLat1 - radLat2;
double b = rad(lng1) - rad(lng2);
double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) +
Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)));
s = s * EARTH_RADIUS;
s = new BigDecimal(s).setScale(3, BigDecimal.ROUND_HALF_UP).doubleValue();
return s;
}
//(116.368904, 39.923423) (116.387271, 39.772501)
public static void main(String[] args) {
double lon1 = 116.368904;
double lat1 = 39.923423;
double lon2 = 116.387271;
double lat2 = 39.772501;
double dist = GetDistance(lat1, lon1, lat2, lon2);
System.out.println("输出结果:" + dist * 1000);
}
}
结果: