从用户获取 X KM 范围内的所有用户
get all the users within X KM range from a user
我有一组用户和他们的 gps 坐标。
我可以使用什么公式来获取 X KM 范围内的所有用户
来自用户?
我需要避免繁重的计算。
我正在考虑对数组进行排序,但我意识到这不是一个好主意,因为我必须为每个用户设置一个排序数组。
使用 Haversine 公式查找距指定点指定距离内的用户:
function getNearbyUsers(lat, lng, distanceInKm, users) {
var R = 6373;
var latRad = lat * Math.PI/180;
var lngRad = lng * Math.PI/180;
var returnUsers = [];
for (var i = 0; i < users.length; i++) {
var lat2Rad = users[i].lat * Math.PI/180;
var lng2Rad = users[i].lng * Math.PI/180;
var dlat = lat2Rad - latRad;
var dlng = lng2Rad - lngRad;
var a = Math.pow(Math.sin(dlat/2),2) + Math.cos(latRad) * Math.cos(lat2Rad) * Math.pow(Math.sin(dlng/2),2);
var c = 2 * Math.atan2(Math.sqrt(a),Math.sqrt(1-a)); // great circle distance in radians
var d = c * R; // Distance from user in km
if (d < distanceInKm) returnUsers.push(users[i]);
}
return returnUsers;
}
我有一组用户和他们的 gps 坐标。 我可以使用什么公式来获取 X KM 范围内的所有用户 来自用户?
我需要避免繁重的计算。 我正在考虑对数组进行排序,但我意识到这不是一个好主意,因为我必须为每个用户设置一个排序数组。
使用 Haversine 公式查找距指定点指定距离内的用户:
function getNearbyUsers(lat, lng, distanceInKm, users) {
var R = 6373;
var latRad = lat * Math.PI/180;
var lngRad = lng * Math.PI/180;
var returnUsers = [];
for (var i = 0; i < users.length; i++) {
var lat2Rad = users[i].lat * Math.PI/180;
var lng2Rad = users[i].lng * Math.PI/180;
var dlat = lat2Rad - latRad;
var dlng = lng2Rad - lngRad;
var a = Math.pow(Math.sin(dlat/2),2) + Math.cos(latRad) * Math.cos(lat2Rad) * Math.pow(Math.sin(dlng/2),2);
var c = 2 * Math.atan2(Math.sqrt(a),Math.sqrt(1-a)); // great circle distance in radians
var d = c * R; // Distance from user in km
if (d < distanceInKm) returnUsers.push(users[i]);
}
return returnUsers;
}