我需要使用 Lua 将 GPS 坐标从 WGS84 转换为十进制。
我确信以前已经完成过,所以我正在寻找代码片段的提示。
更正的问题:在Lua中将DMS(度分秒)转换为DEG((十进制)度)的代码?
例子:
维也纳:dms:48°12'30" N 16°22'28" E
或者
苏黎世:dms:47°21'7" N 8°30'37" E
我发现的困难是从这些字符串中获取数字。
特别是如何处理度(°)分(')和秒(“)的符号。
这样我就可以为每个坐标处理一个表 coord{} 。
coord {1} [48]
coord {2} [12]
coord {3} [30]
coord {4} [N]
coord {5} [16]
coord {6} [22]
coord {7} [28]
coord {8} [E]
感谢建议,谢谢。
将字符串 latlon = '48°12'30" N 16°22'28" E' 解析为 DMS+heading 组件:
-
这是您的字符串(注意转义的单引号):
latlon = '48°12\'30" N 16°22\'28" E'
-
将其分为两个步骤:纬度/经度,然后是每个步骤的组成部分。您需要捕获“()”,忽略标题周围的空格(N 和 E)以及“%s*”:
lat, ns, lon, ew = string.match(latlon, '(.*)%s*(%a)%s*(.*)%s*(%a)')
-
现在 lat 为 48°12'30",ns 为“N”,lon 为 16°22'28",ew 为“E”。对于 lat 的组成部分,一步一步:
-- string.match(lat, '48°12'30"') -- oops the ' needs escaping or us
-- string.match(lat, '48°12\'30"')
-- ready for the captures:
-- string.match(lat, '(48)°(12)\'(30)"') -- ready for generic numbers
d1, m1, s1 = string.match(lat, '(%d+)°(%d+)\'(%d+)"')
d2, m2, s2 = string.match(lon, '(%d+)°(%d+)\'(%d+)"')
-
现在您知道了 (d1, m1, s1, ns) 和 (d2, m2, s2, ew),您有:
sign = 1
if ns=='S' then sign = -1 end
decDeg1 = sign*(d1 + m1/60 + s1/3600)
sign = 1
if ew=='W' then sign = -1 end
decDeg2 = sign*(d2 + m2/60 + s2/3600)
对于您的 lat 值,您将得到 decDeg1 = 48.208333,这是根据在线计算器的正确值(例如http://www.satsig.net/ Degrees-分钟-秒-calculator.htm).
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)