当你知道java中的经度和纬度时,以米为单位计算距离
可能重复:
在Java中使用纬度/经度值
重复:
- 在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位十进制数。
这是我的坐标的第三种方式,所以这个值的代码将是首选:)
基于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; }
您可以使用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
由此产生的距离是在米。
在C ++中,它是这样做的:
#define LOCAL_PI 3.1415926535897932385 double ToRadians(double degrees) { double radians = degrees * LOCAL_PI / 180; return radians; } double DirectDistance(double lat1, double lng1, double lat2, double lng2) { double earthRadius = 3958.75; double dLat = ToRadians(lat2-lat1); double dLng = ToRadians(lng2-lng1); double a = sin(dLat/2) * sin(dLat/2) + cos(ToRadians(lat1)) * cos(ToRadians(lat2)) * sin(dLng/2) * sin(dLng/2); double c = 2 * atan2(sqrt(a), sqrt(1-a)); double dist = earthRadius * c; double meterConversion = 1609.00; return dist * meterConversion; }