美文网首页
mapboxgl实现带箭头轨迹线

mapboxgl实现带箭头轨迹线

作者: GIS兵器库 | 来源:发表于2020-12-31 17:21 被阅读0次

最近在使用mapboxgl实现轨迹展示时,想实现类似高德地图导航轨迹效果,然而并未在网上找到类似示例。经一番研究与尝试,最终解决,效果如下。

202012310104

添加箭头核心代码如下,只需在配置layout中添加symbol-placementsymbol-spacing属性即可:

// 添加箭头图层
function addArrowlayer() {
    map.addLayer({
        'id': 'arrowLayer',
        'type': 'symbol',
        'source': {
            'type': 'geojson',
            'data': routeGeoJson //轨迹geojson格式数据
        },
        'layout': {
            'symbol-placement': 'line',
            'symbol-spacing': 50, // 图标间隔,默认为250
            'icon-image': 'arrowIcon', //箭头图标
            'icon-size': 0.5
        }
    });
}

然而,为实现上述效果,却走了不少弯路。曾尝试集成Leaflet.PolylineDecorator插件核心算法,通过对线的处理,计算每个箭头所在位置以及角度,也能实现上述效果。不过该方案在地图倾斜旋转后,有时会有箭头偏移的bug。

在解决此bug过程中,不经意间看到道路标注都是沿道路线方向,突然有了新的灵感。

重新查看mapboxgl API,发现将layout中的symbol-placement设置为line,即可实现沿着线的方向绘制箭头。

注意:

  1. 我所用图标为右侧方向箭头,结果与实际方向相符,如果图标为向上箭头,需修改icon-rotate为90。
  2. 只把symbol-placement设置为line,箭头间距过于稀疏;需要设置下symbol-spacing参数,symbol-spacing默认值为250,修改为50即可实现文章首页图片效果。

在线示例

在线示例:http://gisarmory.xyz/blog/index.html?demo=MapboxGLPolylineDecorator

代码地址:http://gisarmory.xyz/blog/index.html?source=MapboxGLPolylineDecorator


原文地址:http://gisarmory.xyz/blog/index.html?blog=MapboxGLPolylineDecorator

关注《GIS兵器库》, 第一时间获得更多高质量GIS文章。

本文章采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名《GIS兵器库》(包含链接: http://gisarmory.xyz/blog/),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。

相关文章

  • Leaflet 带箭头轨迹以及沿轨迹带方向的动态marker

    前面写了篇文章,mapboxgl实现带箭头轨迹线[http://gisarmory.xyz/blog/index....

  • mapboxgl实现带箭头轨迹线

    最近在使用mapboxgl实现轨迹展示时,想实现类似高德地图导航轨迹效果,然而并未在网上找到类似示例。经一番研究与...

  • css实现带箭头的流程条

    css实现带箭头的流程条 .navs { height: 100...

  • mapboxGL测量实现

    概述 讲真,MapboxGL里面虽然有测量的功能,但是不太好用,于是就萌生了自己实现的方法。本文几个turf.js...

  • mapboxGL卷帘实现

    概述 卷帘对比是webgis中常见的一种对比方式,本文讲述一下如何在mapboxGL中实现卷帘对比。 效果 实现思...

  • UIBezierPath简单实现带箭头view

    自定义一个view,在里面划线添加ui #import "BeazView.h" @implementation ...

  • CSS实现带箭头的方框

    我们在很多UI框架中看到带箭头的提示框,感觉挺漂亮,但是之前一直不知道其原理,今天网上找了些资料算是弄清楚原理了;...

  • UML工具

    类之间的关系 继承关系 实线带三角箭头 接口实现关系 虚线带三角箭头 组合关系 实现带实菱形,B由A组成且B不存在...

  • Android 带箭头的指引TipLayout实现。

    如上设计图,要求三角形指示器需要动态对齐上面的文本,需要动态的实现对其三角形。 引用方式 实现思路 准备一个三角形...

  • css实现带箭头的流程条

    这篇文章主要给大家介绍了利用CSS实现带箭头的流程条,文中给出了详细的示例代码,对大家具有一定的参考价值,有需要的...

网友评论

      本文标题:mapboxgl实现带箭头轨迹线

      本文链接:https://www.haomeiwen.com/subject/qqrroktx.html