经纬度,表面的含义就是经纬度的平方和,然后开平方。。。一切都没问题。。
但问题不是简单的二维平面,在二维空间中,这样计算是没有问题。。。
但是。。。。。
百度上找了找,大概有三种方式,一个是根据反余弦,一个是根据sin和cosin,第三个是根据提供的一个第三方jar包计算的。。。。
反余弦
具体分析在这里
https://blog.csdn.net/jk940438163/article/details/83147557#commentsedit
package com.zhiliyuchi.web.rest.util;
/**
* @创建人:Young
* @时 间: 2019/3/13
* @描 述: TODO
*/
public class Test {
private static final double EARTH_RADIUS = 6371393; // 平均半径,单位:m;不是赤道半径。赤道为6378左右
/**
* @描述 反余弦进行计算
* @参数 [lat1, lng1, lat2, lng2]
* @返回值 double
* @创建人 Young
* @创建时间 2019/3/13 20:31
**/
public static double getDistance(Double lat1,Double lng1,Double lat2,Double lng2) {
// 经纬度(角度)转弧度。弧度用作参数,以调用Math.cos和Math.sin
double radiansAX = Math.toRadians(lng1); // A经弧度
double radiansAY = Math.toRadians(lat1); // A纬弧度
double radiansBX = Math.toRadians(lng2); // B经弧度
double radiansBY = Math.toRadians(lat2); // B纬弧度
// 公式中“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_RADIUS * acos; // 最终结果
}
public static void main(String[] args) {
//121.717594,31.12055 121.817629,31.090867
double distance = getDistance(31