百度地图jsAPI实时画出运行轨迹,车头实时指向行驶方向,设置角度偏移

本文主要是介绍百度地图jsAPI实时画出运行轨迹,车头实时指向行驶方向,设置角度偏移,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景:公司想要做一个基于百度地图实时展示车的运行轨迹,且在运行过程中需要车头方向随着角度进行变化。

1.先把地图构建出来,然后造一组数据用以画线。

数据格式为:

var PointArr = [ {long:	117.128937	,lat:	36.676339	,route:	30	}]

2.在地图上添加起始点图标,选用数组的第一个对象的经纬度进行定位展示。

addMarker(new BMap.Point(PointArr[0].long, PointArr[0].lat),'起点',map,PointArr);
//调用方法具体为function addMarker(point, name,mapInit,trackUnit) {if(name=="起点"){var myIcon = new BMap.Icon("css/img/startMap.svg", new BMap.Size(45,45),{anchor: new BMap.Size(20, 45)//这句表示图片相对于所加的点的位置mapStart// offset: new BMap.Size(-10, 45), // 指定定位位置// imageOffset: new BMap.Size(0, 0 - 10 * 25) // 设置图片偏移});var marker = new BMap.Marker(point,{icon:myIcon});  // 创建标注mapInit.addOverlay(marker);               // 将标注添加到地图中marker.setAnimation(BMAP_ANIMATION_BOUNCE); //跳动的动画}
}

3.这么多数据想让他展示实时画线的效果,首先是将这些数组一秒钟取出一个,具体几秒根据项目时间需要设置。然后将这些值存储到一个新的数组里面,通过这些数组拿出前后两个值进行画线。

var carMk;//先将终点坐标展示的mark对象定义
var myIcon2 = new BMap.Icon('http://developer.baidu.com/map/jsdemo/img/car.png', new BMap.Size(52,26),{anchor : new BMap.Size(27, 13)});//初始化终点坐标图标
var temporary=[];//定义中间新取出的值放到一个新的数组里面
var i = 0;
var interval = setInterval(function () {if (i >= PointArr.length) {clearInterval(interval);return;}console.log(PointArr[i]);i = i + 1;temporary.push(PointArr[i]);console.log(temporary);drowLine(map,temporary);//画线调用
}, 1000);

每一秒画一次线的方法调用:

function drowLine(map,temporary) {if(temporary && temporary.length>1){//判断数值为两个点时开始进行绘制for(var i=0;i<temporary.length-1;i++){var polyline22 = new BMap.Polyline([new BMap.Point(temporary[i].long, temporary[i].lat),new BMap.Point(temporary[i+1].long, temporary[i+1].lat)],{strokeColor:"red",strokeWeight:7,strokeOpacity:1});   //创建折线map.addOverlay(polyline22);addMarkerEnd(new BMap.Point(temporary[i+1].long,temporary[i+1].lat),'终点',map,temporary[i+1]);//添加图标}}
}
这个时候会遇到每次结束的点图标不清楚,每一次都会画上一个,最后导致页面中很多最后的图标,简直不能直视。解决方法是在画下一次图标时候先将前一个图标清除调,但

removeOverlay这个方法放在哪儿都会报找不到图标的错误,于是解决方法如下:
function addMarkerEnd(point, name,mapInit,trackUnit) {if(name=="终点"){if(carMk){//先判断第一次进来的时候这个值有没有定义,有的话就清除掉上一次的。然后在进行画图标。第一次进来时候没有定义也就不走这块,直接进行画图标mapInit.removeOverlay(carMk);}carMk = new BMap.Marker(point,{icon:myIcon2});  // 创建标注carMk.setRotation(trackUnit.route);//trackUnit.routemapInit.addOverlay(carMk);               // 将标注添加到地图中carMk.setAnimation(BMAP_ANIMATION_BOUNCE); //跳动的动画}
}

好啦,最终实现的效果就是小车可以在地图上实时进行移动,且车头方向根据值进行变化


这篇关于百度地图jsAPI实时画出运行轨迹,车头实时指向行驶方向,设置角度偏移的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/580938

相关文章

PyCharm如何设置新建文件默认为LF换行符

《PyCharm如何设置新建文件默认为LF换行符》:本文主要介绍PyCharm如何设置新建文件默认为LF换行符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录PyCharm设置新建文件默认为LF换行符设置换行符修改换行符总结PyCharm设置新建文件默认为LF

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Java终止正在运行的线程的三种方法

《Java终止正在运行的线程的三种方法》停止一个线程意味着在任务处理完任务之前停掉正在做的操作,也就是放弃当前的操作,停止一个线程可以用Thread.stop()方法,但最好不要用它,本文给大家介绍了... 目录前言1. 停止不了的线程2. 判断线程是否停止状态3. 能停止的线程–异常法4. 在沉睡中停止5

使用Folium在Python中进行地图可视化的操作指南

《使用Folium在Python中进行地图可视化的操作指南》在数据分析和可视化领域,地图可视化是一项非常重要的技能,它能够帮助我们更直观地理解和展示地理空间数据,Folium是一个基于Python的地... 目录引言一、Folium简介与安装1. Folium简介2. 安装Folium二、基础使用1. 创建

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

在VSCode中本地运行DeepSeek的流程步骤

《在VSCode中本地运行DeepSeek的流程步骤》本文详细介绍了如何在本地VSCode中安装和配置Ollama和CodeGPT,以使用DeepSeek进行AI编码辅助,无需依赖云服务,需要的朋友可... 目录步骤 1:在 VSCode 中安装 Ollama 和 CodeGPT安装Ollama下载Olla

如何关闭 Mac 触发角功能或设置修饰键? mac电脑防止误触设置技巧

《如何关闭Mac触发角功能或设置修饰键?mac电脑防止误触设置技巧》从Windows换到iOS大半年来,触发角是我觉得值得吹爆的MacBook效率神器,成为一大说服理由,下面我们就来看看mac电... MAC 的「触发角」功能虽然提高了效率,但过于灵敏也让不少用户感到头疼。特别是在关键时刻,一不小心就可能触

Nginx配置系统服务&设置环境变量方式

《Nginx配置系统服务&设置环境变量方式》本文介绍了如何将Nginx配置为系统服务并设置环境变量,以便更方便地对Nginx进行操作,通过配置系统服务,可以使用系统命令来启动、停止或重新加载Nginx... 目录1.Nginx操作问题2.配置系统服android务3.设置环境变量总结1.Nginx操作问题

解读docker运行时-itd参数是什么意思

《解读docker运行时-itd参数是什么意思》在Docker中,-itd参数组合用于在后台运行一个交互式容器,同时保持标准输入和分配伪终端,这种方式适合需要在后台运行容器并保持交互能力的场景... 目录docker运行时-itd参数是什么意思1. -i(或 --interactive)2. -t(或 --

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的