gpt4 book ai didi

javascript - 根据经度和纬度计算最近位置(来自数据库)的算法

转载 作者:行者123 更新时间:2023-12-01 01:00:39 24 4
gpt4 key购买 nike

我想做的是开发一种算法来计算哪些已知位置最接近所选位置。假设我在数据库中有 7 个位置,当用户选择一个位置时,他应该可以选择查看前 3 个最近的位置(来自数据库)。在数据库中,每个位置都保存有纬度和经度。

知道如何做到这一点吗?

示例:假设列表包含 100 个自行车站位置。我在 5 号车站,我想了解列表中的其他车站位于附近。不是距离,而是他们的位置。

最佳答案

好问题,让我们认为数据库中有以下三个值:

var dataFromDb = [{
"location": "First location",
"lat": "1.28210155945393",
"lng": "103.81722480263163",

}, {
"location": "Second location",
"lat": "1.2777380589964",
"lng": "103.83749709165197",
"location": "Stop 2"
}, {
"location": "Third Location",
"lat": "1.27832046633393",
"lng": "103.83762574759974",
}];

创建一个函数来计算两点之间的距离:

function distanceBetweenTwoPlace(firstLat, firstLon, secondLat, secondLon, unit) {
var firstRadlat = Math.PI * firstLat/180
var secondRadlat = Math.PI * secondLat/180
var theta = firstLon-secondLon;
var radtheta = Math.PI * theta/180
var distance = Math.sin(firstRadlat) * Math.sin(secondRadlat) + Math.cos(firstRadlat) * Math.cos(secondRadlat) * Math.cos(radtheta);
if (distance > 1) {
distance = 1;
}
distance = Math.acos(distance)
distance = distance * 180/Math.PI
distance = distance * 60 * 1.1515
if (unit=="K") { distance = distance * 1.609344 }
if (unit=="N") { distance = distance * 0.8684 }
return distance
}

定义当前位置:

var currentLat = 1.28210155945393;
var currentLng = 103.81722480263163;

查找1KM内的记录:

for (var i = 0; i < data.length; i++) {
if (distance(currentLat, currentLng, data[i].lat, data[i].lng, "K") <= 1) {
console.log(data[i].location);
}
}

关于javascript - 根据经度和纬度计算最近位置(来自数据库)的算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56111647/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com