根据两地经纬度计算两地直线距离

/**
 * 地图坐标类
 */
public class MapPoint {

    // 纬度
    private double lan;
    // 经度
    private double lon;

    public MapPoint() {
    }

    public MapPoint(double lan, double lon) {
        this.lan = lan;
        this.lon = lon;
    }

    public double getLan() {
        return lan;
    }

    public void setLan(double lan) {
        this.lan = lan;
    }

    public double getLon() {
        return lon;
    }

    public void setLon(double lon) {
        this.lon = lon;
    }

}
  • 计算距离的方法
import java.math.BigDecimal;

public class BaiDuDemo {

    public static void main(String[] args) {
        MapPoint start = new MapPoint(40.160645,116.306533);
        MapPoint end = new MapPoint(39.975758,116.341814);
        double distence = getDistence(start, end);
        System.out.println("两地距离为" + distence + "km");
    }

    /**
     * 获取两个地点之间的距离,精确到小数点后两位km
     */
    public static double getDistence(MapPoint start, MapPoint end) {
        // 得到起点经纬度,并转换为角度
        double startLon = (Math.PI / 180) * start.getLon();
        double startLan = (Math.PI / 180) * start.getLan();
        // 得到终点经纬度,并转换为角度
        double endLon = (Math.PI / 180) * end.getLon();
        double endtLan = (Math.PI / 180) * end.getLan();

        // 地球平均直径为12756km,半径为6378km
        double earthR = 6378;

        // 计算公式
        double distence = Math.acos(Math.sin(startLan) * Math.sin(endtLan)
                + Math.cos(startLan) * Math.cos(endtLan) * Math.cos(endLon - startLon)) * earthR;

        return BigDecimal.valueOf(distence).setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue();
    }
}
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值