根据经纬度计算距离 - Java

/**
 * 根据两个位置的经纬度,来计算两地的距离(单位为KM)
 * 参数为double类型
 *  long1 位置1经度
 *  lat1  位置1纬度
 *  long2 位置2经度
 *  lat2  位置2纬度
 */
public class DistanceUtils {
 
  private static final double EARTH_RADIUS = 6378.137;
 
  private static double rad(double d){
      return d * Math.PI / 180.0;
  }
  
  /**
   * 根据两个位置的经纬度,来计算两地的距离
   * @param longitudeUser 用户位置经度
   * @param latitudeUser  用户纬度
   * @param longitudeBook 书柜经度
   * @param latitudeBook  书柜纬度
   * @return 返回距离单位为千米
   */
  public static double GetDistance(double longitudeUser, double latitudeUser, double longitudeBook, double latitudeBook) {
      double a, b, d, sa2, sb2;
      latitudeUser = rad(latitudeUser);
      latitudeBook = rad(latitudeBook);
      a = latitudeUser - latitudeBook;
      b = rad(longitudeUser - longitudeBook);
 
      sa2 = Math.sin(a / 2.0);
      sb2 = Math.sin(b / 2.0);
      d = 2   * EARTH_RADIUS
              * Math.asin(Math.sqrt(sa2 * sa2 + Math.cos(latitudeUser)
              * Math.cos(latitudeBook) * sb2 * sb2));
      return d;
  }
 
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值