AngularJS获取多个坐标之间的距离
Posted
技术标签:
【中文标题】AngularJS获取多个坐标之间的距离【英文标题】:AngularJS Getting distance between multiple coordinates 【发布时间】:2014-08-08 17:07:08 【问题描述】:我正在编写一个具有大量位置的应用程序,所有位置都带有坐标,我希望该应用程序能够按名称或最近的位置搜索位置。我知道如何通过半正弦公式确定两个坐标之间的距离。但是,我希望我的应用程序遍历数组中的每个对象(位置)并向该对象添加一个名为 distance
的新元素,distance
应该是从我的位置到该位置的距离。我有以下代码,我认为应该可以工作,但事实并非如此。有人有什么想法吗?
function GetLocation(location)
myLat = location.coords.latitude;
myLon = location.coords.longitude;
angular.forEach($scope.ASiteLocs, function(object, location)
location.Point.coordinates = location.Point.coordinates.substring(0, clength - 2).split(",");
Lat = location.Point.coordinates[0];
Lon = location.Point.coordinates[1];
function getCoordDistance()
Number.prototype.toRad = function()
return this * Math.PI / 180;
var lat2 = myLat;
var lon2 = myLon;
var lat1 = Lat;
var lon1 = Lon;
var R = 3959; // Radius in miles
//has a problem with the .toRad() method below.
var x1 = lat2 - lat1;
var dLat = x1.toRad();
var x2 = lon2 - lon1;
var dLon = x2.toRad();
var a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
Math.cos(lat1.toRad()) * Math.cos(lat2.toRad()) *
Math.sin(dLon / 2) * Math.sin(dLon / 2);
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
var d = R * c;
object.distance = d;
);
这是地点的样子(只是其中的几个):
"name": "502 Nelson St, Greenville, MS 38701",
"visibility": "0",
"description": "502 Nelson St, Greenville, MS 38701",
"styleUrl": "#waypoint",
"Point":
"coordinates": "-91.05636,33.415485,0"
,
"name": "242 Blackhawk Trace, Galena, IL 61036",
"visibility": "0",
"description": "242 Blackhawk Trace, Galena, IL 61036",
"styleUrl": "#waypoint",
"Point":
"coordinates": "-90.319778,42.390862,0"
,
"name": "3747 Ocean Dr, Vero Beach, FL 32963",
"visibility": "0",
"description": "3747 Ocean Dr, Vero Beach, FL 32963",
"styleUrl": "#waypoint",
"Point":
"coordinates": "-80.358248,27.659094,0"
这是我的工作的一部分,如果这样更容易阅读的话。 http://plnkr.co/edit/nRQc7Ym0lsaK6jQwd626?p=preview
【问题讨论】:
你的函数是从哪里得到 $scope 的? 它被引入应用程序的另一部分。 @msarchet 你在哪里调用getCoordDistance
你定义了函数但从不调用它
不是在forEach()
中调用的吗? @msarchet
【参考方案1】:
当对对象数组使用angular.forEach时,函数的第一个参数是对象,第二个参数是数组索引:
angular.forEach($scope.ASiteLocs, function(location, arrayIndex)
...
location.distance = d;
)
注意 1:您正在将 forEach 中的 location.Point.coordinates 从字符串更改为数组,因此 GetLocation 函数只会工作一次,因为原始位置数组已更改。
注意 2:在循环中定义函数是不好的做法并且“昂贵”
【讨论】:
【参考方案2】:如果您在代码中使用 my npm 包 haversine-calculator
,您的代码会更简洁:
const haversineCalculator = require('haversine-calculator')
const start =
latitude: -23.754842,
longitude: -46.676781
const end =
latitude: -23.549588,
longitude: -46.693210
console.log(haversineCalculator(start, end))
console.log(haversineCalculator(start, end, unit: 'meter'))
console.log(haversineCalculator(start, end, unit: 'mile'))
console.log(haversineCalculator(start, end, threshold: 1))
console.log(haversineCalculator(start, end, threshold: 1, unit: 'meter'))
console.log(haversineCalculator(start, end, threshold: 1, unit: 'mile'))
【讨论】:
以上是关于AngularJS获取多个坐标之间的距离的主要内容,如果未能解决你的问题,请参考以下文章
在MATLAB中知道多个点的位置坐标,怎样求各个点之间的距离?
一旦坐标在 Firebase 中保存为字符串,如何在 CLLLoationDegrees 中获取它们来计算用户之间的距离?