我从How can I transform the coordinates of a Shapefile?开始。
那里的反应使我开始[我认为]正确的轨道,但我仍然无法解决我的问题。
一个问题是我还没有找到正确的预测:https://gis.stackexchange.com/questions/13330/how-can-i-correctly-transform-unproject-from-lcc
编辑:gis网站上的那个问题已得到解答,我能够使用PROJ命令行工具cs2cs重现正确的转换。它看起来像这样:larry$ cs2cs -f "%.8f" +proj=lcc +lat_1=37.06666666666667 +lat_2=38.43333333333333 +lat_0=36.5 +lon_0=-120.5 +x_0=2000000 +y_0=500000.0000000002 +ellps=GRS80 +datum=NAD83 +to_meter=0.3048006096012192 +no_defs +to +proj=lonlat +datum=WGS84 +ellps=WGS84
6011287.4999795845 2100857.2499904726
-122.40375492 37.74919006 0.00000000
现在,我进行了正确的转换,我能够使用RGeo以简单的形式尝试相同的事情:
ruby-1.9.2-p180 :001 > projection_str = ' +proj=lcc +lat_1=37.06666666666667 +lat_2=38.43333333333333 +lat_0=36.5 +lon_0=-120.5 +x_0=2000000 +y_0=500000.0000000002 +ellps=GRS80 +datum=NAD83 +to_meter=0.3048006096012192 +no_defs'
=> " +proj=lcc +lat_1=37.06666666666667 +lat_2=38.43333333333333 +lat_0=36.5 +lon_0=-120.5 +x_0=2000000 +y_0=500000.0000000002 +ellps=GRS80 +datum=NAD83 +to_meter=0.3048006096012192 +no_defs"
ruby-1.9.2-p180 :002 > projection = RGeo::CoordSys::Proj4.new(projection_str)
=> #<RGeo::CoordSys::Proj4:0x805cba18 " +proj=lcc +lat_1=37.06666666666667 +lat_2=38.43333333333333 +lat_0=36.5 +lon_0=-120.5 +x_0=2000000 +y_0=500000.0000000002 +ellps=GRS80 +datum=NAD83 +to_meter=0.3048006096012192 +no_defs +towgs84=0,0,0">
ruby-1.9.2-p180 :003 > desired_str = '+proj=lonlat +datum=WGS84 +ellps=WGS84'
=> "+proj=lonlat +datum=WGS84 +ellps=WGS84"
ruby-1.9.2-p180 :004 > desired = RGeo::CoordSys::Proj4.new(desired_str)
=> #<RGeo::CoordSys::Proj4:0x805271ac " +proj=lonlat +datum=WGS84 +ellps=WGS84 +towgs84=0,0,0">
ruby-1.9.2-p180 :005 > RGeo::CoordSys::Proj4::transform_coords(projection, desired, 6011287.4999795845, 2100857.2499904726 )
=> [-140.92282523143973, 30.16981659183029]
一般情况:有人请指导我如何正确使用此库吗?
非常感谢你寻找。
答案 0 :(得分:2)
作为一个在黑暗中的野生刺,因为我不知道RGeo甚至Ruby,尝试用他们的米当量代替你的坐标:1832244.0944819663048746863094224,640342.57048223700783128534419392(你可能不需要那个小数位数。 ..)另一种可能性是交换坐标 - 也许RGeo做了一些非常规的假设。
如果您能够从Ruby调用可执行文件,则可以使用ogr2ogr转换您的shapefile。