0

我正在为 iPhone 应用程序制作 API。简而言之,我将位置存储在数据库中(纬度/经度)。当用户发送对半径范围内的积分的请求时,比方说,半径为五 (5) 英里,我需要使用一种算法来仅从 MySQL 数据库中给我这些积分。

  1. 如何在坐标中将英里转换为分钟?IE,考虑到经度的逐渐变细的性质,我要添加多少到我正在搜索的坐标以与用户位置进行比较?

2 当您前往地球的不同地点时,考虑经度/纬度变化方式的好公式是什么?

谢谢 :)

4

1 回答 1

0

你从来没有提到你是如何存储数据的,所以我不能给你实际的代码。这只是我想出的东西:

  1. 将所有数据导入一些高效的数据库。优化它以在一定的X / Y范围内有效地拉起坐标
  2. 选择 10x10 平方英里内的所有坐标。将它们导入数组
  3. 使用 aforeach遍历该数组并使用距离公式 ( distance=sqrt((x-x)^2+(y-y)^2))。如果在 5 英里范围内,请将其添加到另一个阵列。如果没有,请忽略它。

我不知道在一个小地方有数千个坐标会有多有效。您可能需要对其进行微调(例如,如果您要找到最近的位置,请先尝试一个较小的盒子)。

我必须同意 Darren 的观点,即 Google Maps API 可能更适合,尽管我以前没有使用过它。

于 2014-07-24T00:25:55.577 回答