靠近经纬度的位置
Near location with lat and long
我想将我当前的纬度和经度与另一个纬度和经度进行比较,并找到离我最近的位置
我该如何计算?
my location :
51.510836, -0.127579
another :
51.547385, 0.020022
51.482876, -0.036542
51.511894, -0.248477
据我了解
你的问题是通过lat long
获得最近的位置
并且您想计算哪一个离您的位置最近
如果是,那么将所有这 3 个经纬度与您所在位置的经纬度一一比较。
最近的位置是距离最短的位置(以公里为单位)。
试试这个。
function getDistanceFromLatLonInKm(lat1,lon1,lat2,lon2) {
var R = 6371; // Radius of the earth in km
var dLat = deg2rad(lat2-lat1); // deg2rad below
var dLon = deg2rad(lon2-lon1);
var a =
Math.sin(dLat/2) * Math.sin(dLat/2) +
Math.cos(deg2rad(lat1)) * Math.cos(deg2rad(lat2)) *
Math.sin(dLon/2) * Math.sin(dLon/2)
;
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
var d = R * c; // Distance in km
return d;
}
function deg2rad(deg) {
return deg * (Math.PI/180)
}
其中 lat1、lon1 是您的位置,而 lat2、lon2 是您想要比较的那些点,只需在循环中应用它并传递比较的位置,最后一个最低的距离就是您的答案。
我想将我当前的纬度和经度与另一个纬度和经度进行比较,并找到离我最近的位置 我该如何计算?
my location :
51.510836, -0.127579
another :
51.547385, 0.020022
51.482876, -0.036542
51.511894, -0.248477
据我了解 你的问题是通过lat long
获得最近的位置并且您想计算哪一个离您的位置最近
如果是,那么将所有这 3 个经纬度与您所在位置的经纬度一一比较。 最近的位置是距离最短的位置(以公里为单位)。 试试这个。
function getDistanceFromLatLonInKm(lat1,lon1,lat2,lon2) {
var R = 6371; // Radius of the earth in km
var dLat = deg2rad(lat2-lat1); // deg2rad below
var dLon = deg2rad(lon2-lon1);
var a =
Math.sin(dLat/2) * Math.sin(dLat/2) +
Math.cos(deg2rad(lat1)) * Math.cos(deg2rad(lat2)) *
Math.sin(dLon/2) * Math.sin(dLon/2)
;
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
var d = R * c; // Distance in km
return d;
}
function deg2rad(deg) {
return deg * (Math.PI/180)
}
其中 lat1、lon1 是您的位置,而 lat2、lon2 是您想要比较的那些点,只需在循环中应用它并传递比较的位置,最后一个最低的距离就是您的答案。