sazima
V2EX  ›  问与答

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

  •  
  •   sazima · Jun 17, 2019 · 3550 views
    This topic created in 2570 days ago, the information mentioned may be changed or developed.

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

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