JSAPI 高德地图应用--车辆的轨迹回放、并附有信息框(上)

         关于车辆的轨迹回放功能方法,主要分为两种,一种是通过标记点moveAlong()的方法,另一种是PathSimplifier是一个轨迹展示组件;两种方法,各有各的优缺点,前者是比较简单,但是不能在中途控制速度;后者的功能比较全面,但是目前依赖Canvas进行绘制,因此不支持IE9及以下浏览器,而且巡航作为动画过程是非常耗费性能的。

        下面我将用不同的方法来实现这个轨迹回放,首先使用一个简单标记点的方法,效果如下:

 具体的代码如下:

function initLine() {
   //首先需要得到一串线路的定位点的数组,如: lineArr = [[116.478935,39.997761],[116.478939,39.997825],[116.478912,39.998549],[116.478912,39.998549],[116.478998,39.998555],[116.478998,39.998555],[116.479282,39.99856],[116.479658,39.998528],[116.480151,39.998453],[116.480784,39.998302],[116.480784,39.998302],[116.481149,39.998184],[116.481573,39.997997],[116.481863,39.997846],[116.482072,39.997718],[116.482362,39.997718],[116.483633,39.998935],[116.48367,39.998968],[116.484648,39.999861]];

   //其次如果需要在车辆移动时展示信息框中每个点的信息,那就需要有个信息框的数据信息:如gpsLocus = [{gdLongitude:116.478935,gdLatitude:39.997761,code:'0',time:'2021-07-28 14:12'},{gdLongitude:116.478939,gdLatitude:39.997825,code:'1',time:'2021-07-28 14:13'}]等等,我就不一一写出来了,总之线路点的经纬度要与信息框的经纬度一一对应才行

      if (trackMarker) {
        // 1、清空之前数据
        map.remove(trackMarker)
        map.remove(trackPolyline)
        map.remove(passedPolyline)
        if (carWindow) {
          carWindow.close()
        }

      }

      //2、创建汽车点位点
      const position = 线路数据的第一个点的经纬度,如:lineArr[0]
     trackMarker = new AMap.Marker({
        map: map,
        position: position,
        icon: 'https://webapi.amap.com/images/car.png',
        offset: new AMap.Pixel(-26, -13),
        autoRotation: true,
        angle: -90,
      })

      // 3、创建信息框
     carWindow = new AMap.InfoWindow({
        offset: new AMap.Pixel(6, -25),
        content: ''
      })

      // 4、绘制轨迹trackPolyline,这个轨迹是相当于总览展示,如果要控制是否显示整条线路的话,可以通过线路的show()和hide()方法控制
     trackPolyline = new AMap.Polyline({
        map: map,
        path: lineArr,
        showDir: true,
        strokeColor: '#28F',  //线颜色
        // strokeOpacity: 1,     //线透明度
        strokeWeight: 6,      //线宽
        // strokeStyle: "solid"  //线样式
        zIndex: 99999,
      })

      // 5、绘制行驶后的颜色
      passedPolyline = new AMap.Polyline({
        map: map,
        strokeColor: '#AF5',  //线颜色
        strokeWeight: 6,      //线宽
        zIndex: 99999,
      })

      // 行驶过后改变颜色
      trackMarker.on('moving', (e) => {
       passedPolyline.setPath(e.passedPath)

      })
      // 6.信息框随车辆移动
      AMap.event.addListener(trackMarker, 'moving', (e) => {
        var lastLocation = e.passedPath[e.passedPath.length - 1]
        carWindow.setPosition(lastLocation)
        //调用信息框的信息,进行对比
       etVehicleSpeedInWidowns(lastLocation)
      })
      // 7.打开速度框
      carWindow.open(map,trackMarker.getPosition())
      // 8.地图自适应缩放
      map.setFitView(trackMarker)
      map.setZoom(10)
    }

        //对比信息框的经纬度与移动中经纬度是否相同,相同就把信息框里的内容展示出来
       function etVehicleSpeedInWidowns (lnglat) {
             for (var i = 0; i < gpsLocus.length; i++) {
        if (lnglat.lat == gpsLocus[i].gdLatitude && lnglat.lng == gpsLocus[i].gdLongitude) {
          const info = trackInfo(gpsLocus[i])
            carWindow.setContent(info.join(''))
          return
        }
      }
    },

    //信息框里的内容自定义
    function  trackInfo (obj) {
      const info = []
      info.push(`<p  style='min-width:200px;'   class='input-item'>设备号 :${obj.code || '未知'}</p>`)
  info.push(`<p  style='min-width:200px;'   class='input-item'>时间:${obj.time|| '未知'}</p>`)
      return info
    }

这里准备工作就做的差不多了,接下来就是控制车辆的运动了:

    //调用开始动画的方法
 function startAnimation () {
        trackMarker.moveAlong(lineArr, 200);//lineArr:指小车运行的路线,200:指运行速度,单位千米/小时
    }
 //暂停动画的方法
    function pauseAnimation () {
        trackMarker.pauseMove();
    }
//继续动画的方法
    function resumeAnimation () {
        trackMarker.resumeMove();
    }
//停止动画的方法
    function stopAnimation () {
        trackMarker.stopMove();
    }

//所以要想动画动起来,就直接调用startAnimation()

  • 7
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue 3.0中使用高德地图 2.0实现车辆轨迹回放时,当车辆暂停后地图移动到地图的中心,可以按照以下步骤进行操作: 1. 首先,在Vue项目中安装高德地图2.0的SDK。可以使用npm或者yarn等工具进行安装。 ```bash npm install @amap/amap-jsapi-loader ``` 2. 在Vue组件中引入高德地图的SDK。 ```javascript import AMapLoader from '@amap/amap-jsapi-loader'; ``` 3. 在Vue组件的mounted钩子函数中加载地图并初始化。 ```javascript mounted() { AMapLoader.load({ key: 'your_amap_api_key', version: '2.0', plugins: ['AMap.Driving'], }).then((AMap) => { // 初始化地图 const map = new AMap.Map('mapContainer', { zoom: 13, // 初始缩放级别 center: [lng, lat], // 初始地图中心点坐标 }); // 其他地图操作逻辑,如添加车辆标记、轨迹回放等 }); }, ``` 4. 监听车辆暂停事件,在暂停时将地图移动到中心点。 ```javascript // 假设有一个暂停按钮,点击按钮后触发暂停事件 handlePause() { // 获取地图对象 const map = this.map; // 获取地图中心点坐标,可以根据具体需求从车辆标记或轨迹数据中获取 const center = [lng, lat]; // 将地图移动到中心点 map.setCenter(center); }, ``` 通过以上步骤,在Vue 3.0中使用高德地图2.0实现车辆轨迹回放时,当车辆暂停后地图移动到地图的中心。注意替换代码中的`your_amap_api_key`为你的高德地图API密钥,并根据实际需求调整地图初始化参数和获取中心点的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值