当你知道java中的经度和纬度时,计算以米为单位的距离

Esp*_*sen 74 java distance latitude-longitude

可能重复:
使用Java中的纬度/经度值

重复:

我需要计算两个坐标给出的两点之间的距离.我正在研究的项目是一个Java项目,所以Java代码会很棒,但也可以给出伪代码,然后我可以自己实现它:)

您可能知道,有三种表示坐标的方法:

  • 度数:分钟:秒(49°30'00"N,123°30'00"W)
  • 度:十进制分钟(49°30.0', - 123°30.0'),(49d30.0m,-123d30.0')
  • 十进制度(49.5000°, - 123.5000°),一般有4-6个十进制数.

这是我的坐标的第三种方式,所以这个值的代码将是首选:)

Esp*_*sen 181

基于stackoverflow的另一个问题,我得到了这个代码..这计算结果以米为单位,而不是英里:)

 public static float distFrom(float lat1, float lng1, float lat2, float lng2) {
    double earthRadius = 6371000; //meters
    double dLat = Math.toRadians(lat2-lat1);
    double dLng = Math.toRadians(lng2-lng1);
    double a = Math.sin(dLat/2) * Math.sin(dLat/2) +
               Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2)) *
               Math.sin(dLng/2) * Math.sin(dLng/2);
    double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
    float dist = (float) (earthRadius * c);

    return dist;
    }
Run Code Online (Sandbox Code Playgroud)

  • 为什么要转换为Float然后再回浮? (17认同)
  • 只需使用6369作为earthRadius而不是Miles,然后将它们转换为公制. (9认同)
  • 地球半径为3958.75英里*英里*.所以你的代码返回里程. (6认同)
  • @swinefeaster:在倒数第二行中有米转换常数,将里程变为米. (5认同)
  • `return(float)(dist*meterConversion)` (3认同)
  • 嗯,这并不重要,但是地球半径大约是**6371公里**而不是6369公里:) (2认同)
  • 准确地说......这会返回**KILOMETERS**中的值,而不是**METERS** (2认同)

Osc*_* S. 24

您可以使用Java Geodesy Library for GPS,它使用Vincenty的公式,该公式考虑了地球表面的曲率.

实现如下:

import org.gavaghan.geodesy.*;

...

GeodeticCalculator geoCalc = new GeodeticCalculator();

Ellipsoid reference = Ellipsoid.WGS84;  

GlobalPosition pointA = new GlobalPosition(latitude, longitude, 0.0); // Point A

GlobalPosition userPos = new GlobalPosition(userLat, userLon, 0.0); // Point B

double distance = geoCalc.calculateGeodeticCurve(reference, userPos, pointA).getEllipsoidalDistance(); // Distance between Point A and Point B
Run Code Online (Sandbox Code Playgroud)

得到的距离以米为单位.