2

我一直在使用 GeoKit for Rails,效果很好。但是,我注意到在拉出很多列表时,加载速度非常慢。

我想知道是不是因为它在返回结果之前查询了谷歌或一些外部资源。如果是这样的话,有没有办法使用原始 lat lng 坐标(我有)在内部简单地计算距离?

或者一个简单的红宝石公式可以为我做到这一点?

4

2 回答 2

6

距离方面:

Geokit-gem 提供了一种计算两点之间距离的方法:

# model has acts_as_mappable
Model.distance_between obj1, obj2, :units => :kms, :formula => :sphere

查找器方面:

Geokit-rails(一个插件)有一个查找器,可以生成 SQL(用于 mysql、postgres 和 SQL server)来计算距离,让你找到一定距离内的行:

Model.find_within(100, :units => :kms)

它计算所有行的距离,但不需要查询外部资源。如果您的表真的很大,它可能会有所帮助(但我不太确定它是否会)通过首先预先计算 lat/lng 范围来缩小范围:

Model.where(:lat => (x-0.05)..(x+0.05), :lng => (y-0.05)..(y+0.05)).find_within(z, :units => :kms)

如果这仍然没有帮助,您将不得不编写一些自定义的 SQL。geokit-rails 的 sql 距离计算在这里: https ://github.com/andre/geokit-rails/tree/master/lib/geokit-rails/adapters

于 2011-07-28T14:29:32.780 回答
1

您可以使用球体的公式来计算曲面上两点的距离。

这是一些用于计算纬度/经度之间距离的 JavaScript 实现(以及其他一些有用的东西)。翻译成红宝石不应该是太多的脑力劳动;-)

http://www.movable-type.co.uk/scripts/latlong.html

于 2011-07-28T13:51:45.407 回答