博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mapbox symbols 层级设置_mapboxgl实现带箭头轨迹线
阅读量:5898 次
发布时间:2019-06-19

本文共 981 字,大约阅读时间需要 3 分钟。

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

添加箭头核心代码如下,只需在配置layout中添加symbol-placement和symbol-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,即可实现沿着线的方向绘制箭头。

注意:我所用图标为右侧方向箭头,结果与实际方向相符,如果图标为向上箭头,需修改icon-rotate为90。

只把symbol-placement设置为line,箭头间距过于稀疏;需要设置下symbol-spacing参数,symbol-spacing默认值为250,修改为50即可实现文章首页图片效果。

在线示例

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

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

你可能感兴趣的文章
springboot 后台运行
查看>>
Solidworks如何打开swb文件
查看>>
面向对象思想(第一天)
查看>>
微信小程序 js逻辑
查看>>
关于 MySQL 的 boolean 和 tinyint(1)
查看>>
linux 安装 sftp
查看>>
最大似然估计(MLE)与最大后验概率(MAP)
查看>>
es6 javascript对象方法Object.assign() 对象的合并复制等
查看>>
物联网架构成长之路(12)-物联网架构小结1
查看>>
emacs 为什么找不到运行程序?
查看>>
SSIS 对数据排序
查看>>
MyBatis小问题-Mapper中错误No constructor found...
查看>>
Linux内核(14) - 二分法与printk
查看>>
基金常识
查看>>
从汇编角度来理解linux下多层函数调用堆栈运行状态
查看>>
Sqlite - constraint failed[0x1555]: UNIQUE constraint failed
查看>>
【Tomcat】Tomcat下设置项目为默认项目
查看>>
Java Socket编程
查看>>
轻量却超强——推荐几款好用的截图工具
查看>>
深度解析!短视频如何成为现象级产品
查看>>