限制大圈子

时间:2015-10-22 20:16:38

标签: javascript great-circle

我需要限制大圆问题的半径。圆圈将延伸直到它击中另一个项目。

我需要它将圆圈的范围限制在5英里

这是我的代码

function find_closest_ticket(ticket, lat, lng) {

//  var lat = map.position.coords.latitude;
//  var lon = map.position.coords.longitude;

//  lat = 24.709254;
//  lng = -81.381927;
var R = 6371; // radius of earth in km
var distances = [];
var closest = -1;

for (i = 0; i < ticket.length; i++) {
  var mlat = ticket[i].soLAT;
  var mlng = ticket[i].soLNG;
  var dLat = rad(mlat - lat);
  var dLong = rad(mlng - lng);
  var a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
  Math.cos(rad(lat)) * Math.cos(rad(lat)) * Math.sin(dLong / 2) * Math.sin(dLong / 2);
  var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
  var d = R * c;
  distances[i] = d;
  if (closest == -1 || d < distances[closest]) {
  closest = i;
  }
  }
return closest;
}

1 个答案:

答案 0 :(得分:0)

首先,令人惊讶的是你使用一个以km为单位返回半径的函数,然后想要将其限制为5英里。你应该下定决心:要么写函数返回里程并以英里为单位加上限制,要么按原样保留函数并将其限制为km(8 km约为5英里)。

如果您想使用里程,请更改此行:

var R = 6371; // radius of earth in km

为:

var R = 3959; // radius of earth in miles

并替换:

return closest;

由:

return Math.min(5, closest);

或者,如果你想坚持km,那么只能替换:

return closest;

由:

return Math.min(8, closest);