根据两点间的经纬度坐标,计算两点间的距离

本文是一个在网上找到的用来计算两点间的距离,两个点采用经纬度坐标进行表示。

直接查看源码:

/**
 * 计算两个经纬度点之间的距离,单位:米
 *
 * @author hxstrive.com
 */
public class CaculateDistance {
    private final static double EARTH_RADIUS = 6378.137;

    private static double rad(double d) {
        return d * Math.PI / 180.0;
    }


    /**
     * 根据两点间经纬度坐标(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 = (s * 10000) / 10;
        return s;
    }


    public static void main(String[] args) {
        System.out.println("距离差" +
                GetDistance(
                        39.936625, 116.424966,
                        30.650303, 114.364468
                        ) + "米");
    }

}
意志命运往往背道而驰,决心到最后会全部推倒。——莎士比亚
0 不喜欢
说说我的看法 -
全部评论(
没有评论
关于
本网站属于个人的非赢利性网站,转载的文章遵循原作者的版权声明,如果原文没有版权声明,请来信告知:hxstrive@outlook.com
公众号