根据经纬度算距离java_java 根据经纬度计算实际距离

这篇博客介绍了在Java中根据经纬度计算两点实际距离的三种方法:反余弦法、sin/cosin法以及使用第三方jar包。每种方法都提供了具体的代码实现,并提到了地球半径对计算结果的影响,提醒读者根据需求选择合适的地球半径值。
摘要由CSDN通过智能技术生成

经纬度,表面的含义就是经纬度的平方和,然后开平方。。。一切都没问题。。

但问题不是简单的二维平面,在二维空间中,这样计算是没有问题。。。

但是。。。。。

百度上找了找,大概有三种方式,一个是根据反余弦,一个是根据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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值