Esp*_*sen 74 java distance latitude-longitude
可能重复:
使用Java中的纬度/经度值
我需要计算两个坐标给出的两点之间的距离.我正在研究的项目是一个Java项目,所以Java代码会很棒,但也可以给出伪代码,然后我可以自己实现它:)
您可能知道,有三种表示坐标的方法:
这是我的坐标的第三种方式,所以这个值的代码将是首选:)
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)
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)
得到的距离以米为单位.
归档时间: |
|
查看次数: |
181274 次 |
最近记录: |