我尝试了以下步骤:
输入:经纬度数据
然后,我会计算一个以该点为中心,东/北坐标值分别加减50米的矩形框。
现在我会将其重新转换为经纬度,并使用下面的脚本:
http://robotics.ai.uiuc.edu/~hyoon24/LatLongUTMconversion.py 我得到的结果就不对了。之前的经度约为7,而现在经度约为2。
zone, easting, northing = LLtoUTM(23, location.get_lat(), location.get_lon())
topUTM = northing + error
bottomUTM = northing - error
leftUTM = easting - error
rightUTM = easting + error
left, top = UTMtoLL(23, leftUTM, topUTM, zone)
我的代码有错误吗,还是可能是脚本出了问题?
我尝试使用 pyproj 将经纬度转换为 UTM,再将其转换回经纬度,以查看会发生什么。
>>> p = pyproj.Proj(proj='utm', zone=32, ellps='WGS84')
>>> p
<pyproj.Proj object at 0x7ff9b8487dd0>
>>> x,y = p(47.9941214, 7.8509671)
>>> print x,y
5159550.36822 1114087.43925
>>> print p(x,y,inverse=True)
(47.971558538495991, 7.8546573140162605)
这里的结果与上面的脚本相比不是极端偏差那么大了,但仍然不够准确,无法使用。为什么会这样?我该怎么做才能得到更精确的结果?
编辑:
我运行了test(),所有测试都通过了。
在epsg文件中没有这样的东西。 我找到的最接近的是这个:
<32632> +proj=utm +zone=32 +ellps=WGS84 +datum=WGS84 +units=m +no_defs <>
没有tmerc。那么我需要传递哪些参数作为towgs84?就上面那些参数吗?