我有一个包含纬度和经度列表的数据库
-DeviceName
-Latitude
-Longitude
鉴于我当前设备的纬度和经度,我想获取数据库列表中距离/接近 X 公里的所有设备。
如何计算我的位置与其他位置的距离?
我有一个包含纬度和经度列表的数据库
-DeviceName
-Latitude
-Longitude
鉴于我当前设备的纬度和经度,我想获取数据库列表中距离/接近 X 公里的所有设备。
如何计算我的位置与其他位置的距离?
我想你想看看这个惊人的演示。它会告诉你如何使用(并解释加分!)haversine 公式来计算地球表面的距离,考虑曲率以及如何避免数据库查询中的一些常见错误等。他的数据集几乎就是什么你的是 - 项目,经度和纬度。
如果您追求原始代码,这应该可以帮助您:
private static Double rad2deg(Double rad) {
return (rad / Math.PI * 180.0);
}
private static Double deg2rad(Double deg) {
return (deg * Math.PI / 180.0);
}
private const Double kEarthRadiusKms = 6376.5;
private static Double CalculateDistance(Double latitude1, Double longitude1, Double latitude2, Double longitude2) {
double theta = longitude1 - longitude2;
double dist = Math.Sin(deg2rad(latitude1)) * Math.Sin(deg2rad(latitude2)) + Math.Cos(deg2rad(latitude1)) * Math.Cos(deg2rad(latitude2)) * Math.Cos(deg2rad(theta));
dist = Math.Acos(dist);
dist = rad2deg(dist);
dist = dist * 60 * 1.1515;
dist = dist * 1.609344;
return (dist);
}