V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
sazima
V2EX  ›  问与答

地图上的路线轨迹在数据库中是怎上存储的

  •  
  •   sazima · 2019-06-17 13:47:47 +08:00 · 3004 次点击
    这是一个创建于 1768 天前的主题,其中的信息可能已经有所发展或是发生改变。

    比如某某打车的线路图, 是怎么标记的历史线路的呢?

    11 条回复    2019-06-17 16:49:03 +08:00
    opengps
        1
    opengps  
       2019-06-17 13:50:37 +08:00   ❤️ 1
    一组坐标信息而已:客户端 id,经度,纬度,速度,角度,时间
    opengps
        2
    opengps  
       2019-06-17 13:58:51 +08:00
    如果是关系型数据存储,分享下我之前用过的 https://www.opengps.cn/Blog/View.aspx?id=284
    kzfile
        3
    kzfile  
       2019-06-17 14:03:11 +08:00
    我们存就是存到专门的地理类型字段.
    当然,存之前,还是需要处理一下,去除多余点
    sujin190
        4
    sujin190  
       2019-06-17 14:11:15 +08:00
    这不就是和录音差不多原理么,按固定时间采样,比如 1 秒采样当前经纬度、速度和时间,然后压缩就可以了啊,压缩也就是去除相同方向速度的不同时间重复数据就可以了,最后数组保存就是了
    sujin190
        5
    sujin190  
       2019-06-17 14:12:15 +08:00
    而且压缩之后只需保存经纬度和时间就可以了,并不复杂吧
    sazima
        6
    sazima  
    OP
       2019-06-17 15:11:24 +08:00
    @sujin190 @opengps @kzfile 也就是存一串, 前端根据坐标画出来路线是吗?
    sazima
        7
    sazima  
    OP
       2019-06-17 15:11:56 +08:00
    @sujin190 @opengps @kzfile 也就是存一串连续的坐标, 前端根据坐标画出来路线是吗?
    sujin190
        8
    sujin190  
       2019-06-17 15:20:08 +08:00
    @sazima #7 对啊,再说地图本来也支持一堆坐标点绘路线图吧,不需要索引的话确实这样就可以了
    xiang578
        9
    xiang578  
       2019-06-17 15:23:13 +08:00
    从地图数据商那里买过来的数据会将现实中道路转换成 link,link 会有起点和终点的 geo 坐标,数据库中会保存路线的 link 序列,前端展示时根据 link,去查 link 转 geo 表来画图。
    xiang578
        10
    xiang578  
       2019-06-17 15:24:45 +08:00
    @xiang578 #9 补充一下 link 相当于图论中的边
    opengps
        11
    opengps  
       2019-06-17 16:49:03 +08:00
    @sazima 点的按顺序连线,就是线,参考百度地图的折线覆盖物 http://lbsyun.baidu.com/jsdemo.htm#c1_1
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5276 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 07:50 · PVG 15:50 · LAX 00:50 · JFK 03:50
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.