-2

大円問題の半径を制限する必要があります。円は別のアイテムに当たるまで伸びます。

円の範囲を 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;
}
4

1 に答える 1

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);
于 2015-10-22T20:40:24.600 に答える