我正在写一个相对简单的应用程序,其中我使用RGeo来计算地球上的点之间的距离。我正在使用RGeo::Geographic.spherical_factory来完成这项工作。
现在,我希望能够通过向现有点添加偏移来创建新点。例如,我希望能够找到现有点以北500米和以东200米的点的经度和纬度。
我该怎么做呢?
发布于 2014-07-11 08:04:30
也许这会有帮助:
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_factory和RGeo::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
https://stackoverflow.com/questions/21432349
复制相似问题