Java 判断两个经纬度之间的直线距离
public class GeoUtil {
/**
* zhe-获取两个经纬度之间的直线距离
* @date 2022/1/6 10:00
* @param lonA 地点A的经度
* @param latA 地点A的维度
* @param lonB 地点B的经度
* @param latB 地点B的维度
*/
public static int getDistance(Double lonA, Double latA, Double lonB, Double latB){
// 地球半径
double R = 6371;
//开始经度
double lon1 = (Math.PI / 180) * lonA;
//开始纬度
double lat1 = (Math.PI / 180) * latA;
//结束经度
double lon2 = (Math.PI / 180) * lonB;
//结束纬度
double lat2 = (Math.PI / 180) * latB;
// 两点间距离 km,如果想要米的话,结果*1000就可以了
double km = Math.acos(Math.sin(lat1) * Math.sin(lat2) + Math.cos(lat1) * Math.cos(lat2) * Math.cos(lon2 - lon1)) * R;
return (int) (km * 1000);
}
}