使用Java获取两个地点的距离(米),或者是两个经纬度的距离

    最近在写地图项目 ,要计算两个点经纬度的用的很多,就在百度地图开放平台里面找了个工具方法,觉得大家可能很多人都需要,那我就把他放上来有注释版本,方便大家知道他是做了什么事情,如何计算出来的(百度地图提供的没有注释)

   /**
     * 计算两个经纬度间距离 返回值为这两个坐标之间的距离(单位:米)
     * @param lat_a 第一个点的纬度
     * @param lng_a 第一个点的经度
     * @param lat_b 第二个点的纬度
     * @param lng_b 第二个点的经度
     * @return
     */
    public static double getDistance(double lat_a, double lng_a, double lat_b, double lng_b){
        double pk = 180 / 3.14169;  // 地球周长与直径的比例
        // a1、a2、b1、b2:将纬度和经度转换为弧度后的值
        double a1 = lat_a / pk;
        double a2 = lng_a / pk;
        double b1 = lat_b / pk;
        double b2 = lng_b / pk;
        //  t1、t2、t3:三个余弦值,用于后续计算
        double t1 = Math.cos(a1) * Math.cos(a2) * Math.cos(b1) * Math.cos(b2);
        double t2 = Math.cos(a1) * Math.sin(a2) * Math.cos(b1) * Math.sin(b2);
        double t3 = Math.sin(a1) * Math.sin(b1);
        // 两个坐标之间的距离(弧度)
        double tt = Math.acos(t1 + t2 + t3);
        // 6371000:地球半径,单位为米
        return 6371000 * tt;
    }
更外 3.14169为圆周率的近似值,如果需要追求高精准度 可使用jdk提供的Math.PI

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用以下代码来计算两个经纬度值之间的距离: ``` import java.lang.*; import java.util.*; public class Main { public static void main(String[] args) { // 第一个点的经纬度 double lat1 = 30.5; double lon1 = 104.0; // 第二个点的经纬度 double lat2 = 31.5; double lon2 = 105.0; // 地球半径,单位是公里 double R = 6371.0; double dLat = Math.toRadians(lat2 - lat1); double dLon = Math.toRadians(lon2 - lon1); lat1 = Math.toRadians(lat1); lat2 = Math.toRadians(lat2); double a = Math.sin(dLat / 2) * Math.sin(dLat / 2) + Math.sin(dLon / 2) * Math.sin(dLon / 2) * Math.cos(lat1) * Math.cos(lat2); double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); double d = R * c; System.out.println(d); } } ``` 其中,lat1和lon1表示第一个点的纬度和经度,lat2和lon2表示第二个点的纬度和经度,计算出来的d就是两点之间的距离单位是公里。 这段代码使用的是球面距离公式,公式如下: d = R * arccos(sin(lat1) * sin(lat2) + cos(lat1) * cos(lat2) * cos(lon1 - lon2)) 其中,d是两点之间的距离,R是地球的半径,lat1和lon1是第一个点的纬度和经度,lat2和lon2是第二个点的纬度和经度。 ### 回答2: 要使用Java计算两个经纬度之间的距离,可以使用Haversine公式。这个公式是通过计算地球上两个点之间的直线距离来估算地球表面上的距离。 我们可以根据以下步骤实现: 1. 首先,将经纬度从度转换为弧度。因为Haversine公式需要用到弧度值来计算距离。可以使用Math.toRadians方法将度数转换为弧度。 2. 使用Haversine公式计算两个点之间的距离。公式如下: a. 计算两个纬度之间的差值。 b. 计算两个经度之间的差值。 c. 使用半正矢量公式计算两个点之间的弧长。 d. 将弧长乘以地球的半径(以单位)获得距离。 3. 返回距离。 以下是使用Java实现这个算法的示例代码: ```java import java.lang.Math; public class DistanceCalculator { private static final double EARTH_RADIUS = 6371.0; // 地球的半径(以公里为单位) public static double calculateDistance(double lat1, double lon1, double lat2, double lon2) { double latDistance = Math.toRadians(lat2 - lat1); double lonDistance = Math.toRadians(lon2 - lon1); double a = Math.sin(latDistance / 2) * Math.sin(latDistance / 2) + Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2)) * Math.sin(lonDistance / 2) * Math.sin(lonDistance / 2); double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); double distance = EARTH_RADIUS * c; // 距离(以公里为单位) return distance; } public static void main(String[] args) { double lat1 = 40.7128; // 第一个点的纬度 double lon1 = -74.0060; // 第一个点的经度 double lat2 = 34.0522; // 第二个点的纬度 double lon2 = -118.2437; // 第二个点的经度 double distance = calculateDistance(lat1, lon1, lat2, lon2); System.out.println("两个点之间的距离为:" + distance + "公里"); } } ``` 该程序会输出两个点之间的距离(以公里为单位)。可以使用类似的方法将距离以其他单位(如)输出。 ### 回答3: 使用Java计算两个经纬度值间的距离可以使用Haversine公式来实现。Haversine公式是一种用于计算球面两点距离算法,通过考虑球体的曲率来计算两点之间的大圆距离。 首先,我们需要将经度和纬度转换为弧度表示。将经纬度的度数除以180,并用Math.toRadians()方法将其转换为弧度。例如,将纬度度数转换为弧度的代码如下: double lat1Rad = Math.toRadians(lat1); double lat2Rad = Math.toRadians(lat2); 然后,可以使用Haversine公式计算两个点之间的距离。公式如下: double lonDiff = Math.toRadians(lon2 - lon1); double latDiff = lat2Rad - lat1Rad; double a = Math.pow(Math.sin(latDiff / 2), 2) + Math.cos(lat1Rad) * Math.cos(lat2Rad) * Math.pow(Math.sin(lonDiff / 2), 2); double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); double distance = R * c; 其中,R是地球的半径,可以根据需求选择不同的单位。例如,如果需要以公里为单位计算距离,则可以使用6371千作为地球的半径。 最后,可以将计算得到的距离输出或进一步处理。 这就是使用Java计算两个经纬度值间距离的基本步骤。通过使用Haversine公式,我们可以方便地计算球面上任意两点之间的距离

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值