获取用户在X KM范围内的所有用户

时间:2015-04-26 20:41:43

标签: javascript haversine

我有一组用户及其gps坐标。 我可以使用什么公式来获取X KM范围内的所有用户 来自用户?

我需要避免繁重的计算。 我正在考虑对数组进行排序,但我意识到这不是一个好主意,因为我必须为每个用户设置一个排序数组。

1 个答案:

答案 0 :(得分:0)

使用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;
}