【发布时间】:2011-07-04 14:09:21
【问题描述】:
我有一些传递地理位置坐标的二进制数据流 - 纬度和经度。我需要找到它们的编码方法。
4adac812 = 74°26.2851' = 74.438085
2b6059f9 = 43°0.2763' = 43.004605
4adaee12 = 74°26.3003' = 74.438338
2a3c8df9 = 42°56.3177' = 42.938628
4ae86d11 = 74°40.1463' = 74.669105
2afd0efb = 42°59.6263' = 42.993772
第一个值是十六进制值。第 2 和第 3 是我在输出中得到的值(不确定在转换中使用了哪一个)。
我发现第一个字节代表值的整数部分(0x4a = 74)。但我找不到小数部分是如何编码的。
非常感谢任何帮助!
谢谢。
--
Upd:这个流通过 tcp 协议来自一些“中国”gps 服务器软件。我没有 clent 软件的资源或文档。我想它是用 VC++6 编写的,并使用了一些标准实现。
--
更新:这是我收到的数据包:
Hex data:
41 00 00 00 13 bd b2 2c
4a e8 6d 11 2a 3c 8d f9
f6 0c ee 13
Log data in client soft:
[Lng] 74°40.1463', direction:1
[Lat] 42°56.3177', direction:1
[Head] direction:1006, speed:3318, AVA:1
[Time] 2011-02-25 19:52:19
Result data in client (UI):
74.669105
42.938628
Head 100 // floor(1006/10)
Speed 61.1 // floor(3318/54.3)
41 00 00 00 b1 bc b2 2c
4a da ee 12 2b 60 59 f9
00 00 bc 11
[Lng] 74°26.3003', direction:1
[Lat] 43°0.2763', direction:1
[Head] direction:444, speed:0, AVA:1
[Time] 2011-02-25 19:50:49
74.438338
43.004605
00 00 00 00 21 bd b2 2c
4a da c8 12 aa fd 0e fb
0d 0b e1 1d
[Lng] 74°26.2851', direction:1
[Lat] 42°59.6263', direction:1
[Head] direction:3553, speed:2829, AVA:1
[Time] 2011-02-25 19:52:33
74.438085
42.993772
我不知道前 4 个字节是什么意思。
我发现第 5 个字节的低 7 位代表秒数。 (也许 5-8 位是时间?) 字节 9 表示 Lat 的整数。
字节 13 是 Lng 的整数。
字节 17-18 反转(字字节)是速度。
字节 19-20 反转为 ava(?) 和方向(4 + 12 位)。 (顺便说一句,有人知道 ava 是什么吗?)
还有一个音符。在第 3 个数据包的第 13 个字节中,您可以看到仅使用了低 7 位。我猜第 1 位并不意味着什么(我一开始就删除了,如果我错了,请见谅)。
【问题讨论】:
-
流来自什么设备?
-
这是一个非常甜蜜的谜题。
-
是的,请发布二进制数据包。即使它是一个中国随机数生成器,我们也应该能够想出一些疯狂的公式来推导出它。 :)
-
你说:“我想它是用 VC++6 编写的” 你有 VC 项目吗?源代码将是解决这个问题的理想选择,呵呵。如果没有,但您可以给我们一份客户端程序的副本:这样我们就可以在调试器中查看它。
-
是的,能够分析二进制文件可能是获取此信息的最直接方式。
标签: binary hex coordinates