double lon1 = Math.toRadians(longitude1);
double lon2 = Math.toRadians(longitude2);
// 纬度之差
double a = lat1 - lat2;
// 经度之差
double b = lon1 - lon2;
// 计算两点距离的公式
double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) + Math.cos(lat1) * Math.cos(lat2) * Math.pow(Math.sin(b / 2), 2)));
// 弧长乘赤道半径, 返回单位: 米
s = s * EQUATOR_RADIUS;
return s;
}
}
### 2.方法二
package com.test.java.util;
/**
-
坐标位置相关util
*/
public class PositionUtil {/**
- 地球平均半径(单位:米)
*/
private static final double EARTH_AVG_RADIUS = 6371000;
/**
-
方法二:(反余弦计算方式)
-
@param longitude1 第一点的经度
-
@param latitude1 第一点的纬度
-
@param longitude2 第二点的经度
-
@param latitude2 第二点的纬度
-
@return 返回的距离,单位m
*/
public static double getDistance3(double longitude1, double latitude1, double longitude2, double latitude2) {
// 经纬度(角度)转弧度。弧度作为作参数,用以调用Math.cos和Math.sin
// A经弧度
double radiansAX = Math.toRadians(longitude1);
// A纬弧度
double radiansAY = Math.toRadians(latitude1);
// B经弧度
double radiansBX = Math.toRadians(longitude2);
// B纬弧度
double radiansBY = Math.toRadians(latitude2);// 公式中“cosβ1cosβ2cos(α1-α2)+sinβ1sinβ2”的部分,得到∠AOB的cos值
double cos = Math.cos(radiansAY) * Math.cos(radiansBY) * Math.cos(radiansAX - radiansBX) + Math.sin(radiansAY) * Math.sin(radiansBY);
// System.out.println("cos = " + cos); // 值域[-1,1]// 反余弦值
double acos = Math.acos(cos);
// System.out.println("acos = " + acos); // 值域[0,π]
// System.out.println("∠AOB = " + Math.toDegrees(acos)); // 球心角 值域[0,180]// 最终结果
return EARTH_AVG_RADIUS * acos;
}
- 地球平均半径(单位:米)
}
### 3.方法三
基于谷歌地图的计算公式计算距离
package com.test.java.util;
/**
-
坐标位置相关util
*/
public class PositionUtil {/**
- 地球平均半径(单位:米)
*/
private static final double EARTH_AVG_RADIUS = 6371000;
/**
- 经纬度转化为弧度(rad)
- @param d 经度/纬度
*/
private static double rad(double d) {
return d * Math.PI / 180.0;
}
/**
- 方法三:(基于googleMap中的算法得到两经纬度之间的距离,计算精度
- 地球平均半径(单位:米)