解决百度地图轨迹动画库原始点丢失问题

背景

新需求需要使用百度地图的轨迹动画服务,于是使用了百度地图轨迹库BMapGLLib,结果使用到项目中时遇到了一些问题

问题1:迟迟不更新的文档

官方文档更新的时间过于久远,按照文档引入的api和最新的存在出入。

比如:文档类方法参考中,未出现pause() continue() 等动画方法;

文档未更新还会导致不能正确引入BMapGLLib地址

文档中:

html 复制代码
//正确的
<script src="//mapopen.bj.bcebos.com/github/BMapGLLib/TckAnimation/src/TrackAnimation.min.js"></scrip>
//文档中非最新的api地址
<script type="text/javascript" src="//api.map.baidu.com/library/TrackAnimation/src/TrackAnimation_min.js"></script>

正确的地址只能在示例中看到

问题2: 轨迹点丢失问题

这是原始轨迹生成的polyline,大概有2000个轨迹点。

而使用轨迹库后,跳过了播放过程直接出现整个polyline,而且视角还在移动,这显然是不合理的。

于是经过一番debug后定位到了问题

这个函数的本意是用于扩充原始路径。它通过计算路径上每个点之间的距离,将路径按一定比例扩充为多个点,实现更加平滑地实现动画效果。

结果很明显,输入的点位高达3000个,经过这个函数的计算扩充过的点位数组归零了(百度你在干什么啊)。

当时我就很难绷

原因很容易分析:

js 复制代码
      var percent = (distances[i - 1] / totalDistance).toFixed(2);

当点位距离占总距离的占比不足百分之一的时候,这个点位直接消失不见了

所以结论很明显了

当轨迹点位超过100时,这个轨迹库就不能正常工作

这是十分严重但也十分低级的问题,只要把toFixed(2) 去掉就能解决

随便就能测试出的问题,却能一直存在,让我感觉是不是自己的姿势不对。

最后我把这个库复制了一份到本地,改了这个地方,问题就完美解决了

结语

不知道这么明显的问题没人解决,可能没啥人用,百度也就摆烂了。 最后给提了一个pr

相关推荐
李明卫杭州3 分钟前
使用 computed 处理 v-model 复杂数据结构
前端·javascript·vue.js
丨我是张先生丨24 分钟前
日语单词 Web Page
前端·css·css3
禅思院2 小时前
AI对话前端从入门到崩溃:一个长对话引发的五层优化战争【引子】
前端·面试·架构
TrisighT2 小时前
Electron 鸿蒙 PC 上点外链唤醒应用,我试了 6 种写法只有 1 种能跑
前端·electron·harmonyos
2501_930707783 小时前
如何将HTML文件转换为纯文本(详细步骤指南)
前端·html
天才熊猫君3 小时前
配置与数据分离:一种可视化搭建的属性编辑方案
前端·javascript
林希_Rachel_傻希希4 小时前
web性能之相关路径——AI总结
前端·javascript·面试
竹林8184 小时前
用 wagmi v2 踩坑两天,我终于搞懂了多链钱包切换在 DeFi 前端中的正确姿势
前端·javascript
用户2136610035724 小时前
Vue项目搜索功能与面包屑导航
前端·javascript
星栈4 小时前
LiveView 的实时通信,爽是爽,但 PubSub 和广播也最容易把自己绕晕
前端·前端框架·elixir