在RGeo中按偏移创建点

时间:2014-01-29 13:21:11

标签: ruby rgeo

我正在编写一个相对简单的应用程序,其中我使用RGeo来计算地球上各点之间的距离。我正在使用RGeo::Geographic.spherical_factory

这样做

现在我希望能够通过向现有点添加偏移量来创建新点。例如,我希望能够找到现有点以北500米和以东200米的点的经度和纬度。

我该怎么做呢?

1 个答案:

答案 0 :(得分:1)

也许这会有所帮助:

a = move_point(-72.4861, 44.1853, 0, 0)     # POINT (-72.4861 44.18529999999999)
b = move_point(-72.4861, 44.1853, 100, 0)   # POINT (-72.48520168471588 44.18529999999999)
c = move_point(-72.4861, 44.1853, 0, 100)   # POINT (-72.4861 44.18594416889434)
puts a.distance(b)
puts a.distance(c)

哪个给你

99.99999999906868
99.99999999906868

注意:我不确定RGeo::Geographic.simple_mercator_factoryRGeo::Geographic.spherical_factory之间的区别是什么。

require 'rgeo'

def move_point(lon, lat, x_offset_meters, y_offset_meters)
  wgs84 = RGeo::Geographic.simple_mercator_factory.point(lon, lat)
  wgs84_factory = wgs84.factory
  webmercator = wgs84_factory.project wgs84
  webmercator_factory = webmercator.factory
  webmercator_moved = webmercator_factory.point(webmercator.x+x_offset_meters, webmercator.y+y_offset_meters)
  wgs84_factory.unproject webmercator_moved
end

来自How to move a point in Rgeo