如何根据纬度和经度获取两个位置之间的距离



我正在尝试根据用户到每个位置的距离显示一个列表。这些位置以 JSON 形式从 Firebase 接收。

要获取用户位置,我正在使用:

    navigator.geolocation.getCurrentPosition(function(position) {
        var latitude = position.coords.latitude;
        var longitude = position.coords.longitude;

您是否知道一种按距离对此 JSON 进行排序并列出它(具有多个子节点)的方法?

谢谢。

有两种方法可以获取纬度/经度到其他纬度/经度之间的距离:

- 使用谷歌接口

    function getDistanceOneToOne(lat1, lng1, lat2, lng2)
    {
       const Location1Str = lat1 + "," + lng1;
       const Location2Str = lat2 + "," + lng2;
       let ApiURL = "https://maps.googleapis.com/maps/api/distancematrix/json?";
       let params = `origins=${Location1Str}&destinations=${Location2Str}&key=${GOOGLE_API_KEY}`; // you need to get a key
       let finalApiURL = `${ApiURL}${encodeURI(params)}`;
       let fetchResult =  await fetch(finalApiURL); // call API
       let Result =  await fetchResult.json(); // extract json
       return Result.rows[0].elements[0].distance;
    }

这需要在移动设备上进行网络连接,但它提供行驶距离(与驾驶导航器完全相同)以及更多信息(例如,到达的持续时间),这与提供直线距离的第二种方法不同。

对于上述内容,您需要获取Google Api密钥。更多信息在这里: 谷歌地图API

- 使用纯数学

这发生在本地设备上,它提供了两个纬度/经度之间的直线距离。

function distance(lat1, lon1, lat2, lon2, unit) {
    var radlat1 = Math.PI * lat1/180
    var radlat2 = Math.PI * lat2/180
    var theta = lon1-lon2
    var radtheta = Math.PI * theta/180
    var dist = Math.sin(radlat1) * Math.sin(radlat2) + Math.cos(radlat1) * Math.cos(radlat2) * Math.cos(radtheta);
    dist = Math.acos(dist)
    dist = dist * 180/Math.PI
    dist = dist * 60 * 1.1515
    if (unit=="K") { dist = dist * 1.609344 }
    if (unit=="M") { dist = dist * 0.8684 }
    return dist
}

为每个项目运行上述一项,您将获得每个项目的距离。希望有帮助。

相关内容

  • 没有找到相关文章

最新更新