美文网首页
Leaflet 带箭头轨迹以及沿轨迹带方向的动态marker

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

作者: GIS兵器库 | 来源:发表于2021-03-02 17:38 被阅读0次

    前面写了篇文章,mapboxgl实现带箭头轨迹线,介绍了如何基于mapboxgl实现类似高德地图导航轨迹效果。

    近期有基于Leaflet实现轨迹回放的需求,于是研究了下如何基于leaflet来实现。

    下图是我基于leaflet实现的效果。

    202101280101

    接下来分享一下在我基于leaflet实现该效果时一些思路以及踩到的坑。

    轨迹线添加箭头效果

    leaflet无法像mapboxgl似的直接通过样式实现轨迹箭头效果,需要通过引用L.polylineDecorator扩展实现。核心代码如下。

    注意:此处添加箭头图层应在轨迹线和实时轨迹线之后,不然箭头会被覆盖。

    20210204103224

    沿轨迹线带方向动态marker

    实现该效果首先想到的是类似之前在用mapboxgl 实现的思路,将线打断,然后通过requestAnimationFrame循环更新marker的位置和角度实现;这种方式最终可以实现动态效果,但是流畅度差了一些,会有卡顿的现象。

    为了得到更流畅的效果,又翻看Leaflet Plugins,搜索animate关键字,发现了Leaflet.AnimatedMarker,动画效果挺流畅的,于是拉取代码研究了一下。

    该插件主要是使用CSS3动画来实现marker在线段间的移动,所以效果比较流畅。

    但是该插件并未考虑marker角度的问题,而且在做地图缩放的时候会有marker偏移轨迹的问题。查找相关资料时,发现有人也尝试解决此问题leaflet-moving-marker

    但这里对于轨迹线的动态绘制并未考虑。

    参考Leaflet.AnimatedMarkerleaflet-moving-marker中核心代码并考虑我们要实现的效果,最终解决了角度问题以及轨迹线动态绘制问题。

    20210208152058

    另外,在播放过程中当前后两个点位角度变化超过180度时,会出现marker旋转的问题。

    202102080101

    通过如下代码我们解决了此问题。

    20210208152905

    我们把代码重新封装,简单调用即可实现了文章开头的轨迹带箭头以及沿轨迹线带方向的动态marker

    20210302124540

    注意:在动态播放的过程中缩放地图,标记点由于播放延迟,有时仍然会出现偏离轨迹线的问题,目前该问题暂未解决,后续解决后更新。

    总结

    1. 使用用L.polylineDecorator插件可以实现轨迹带箭头效果。
    2. Leaflet.AnimatedMarker插件可以更流畅的实现marker沿线播放,但是没有考虑marker角度和轨迹线的动态绘制。
    3. 参考Leaflet.AnimatedMarkerleaflet-moving-marker中核心代码,解决角度问题以及轨迹线动态绘制等问题。
    4. 将代码重新封装成插件,方便调用。

    在线示例

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

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

    插件地址:http://gisarmory.xyz/blog/index.html?source=LeafletAnimatedMarker


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

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

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

    相关文章

      网友评论

          本文标题:Leaflet 带箭头轨迹以及沿轨迹带方向的动态marker

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