在vue3中引入高德地图并实现路线规划以及加入途经点!超简单!!!

在一个新的项目中引入高德地图,首先要下载地图的加载文件

npm i @amap/amap-jsapi-loader

 然后就可以直接开始了

话不多说,直接上代码了

<template>
  <div class="about">
    <div class="content" id="container"></div>
    <div id="panel"></div>
    <div class="btnbox">
      <div class="btn" @click="jump(item.value)" v-for="item in dataList" :key="item.name">{{ item.name }}</div>
    </div>

  </div>
</template>
<script setup>
import { onMounted, ref } from 'vue'
import AMapLoader from "@amap/amap-jsapi-loader";
window._AMapSecurityConfig = {
  securityJsCode: '你的秘钥',
}
const dataList = ref([
  { name: '苏州博物馆', value: [120.63,31.32] },
  { name: '尹山湖', value: [120.69,31.24] },
  { name: '同里古镇', value: [120.72,31.16] },
  { name: '甪直古镇', value: [120.87,31.27] },
])
var map = null
var driving = null
var Amap2 = null
const getMap = () => {
  console.log('getMap')
  // 配置高德地图的key
  AMapLoader.load({
    "key": "你自己的key",
    "version": "1.4.15",
    "plugins": [
      "AMap.InfoWindow",//地图弹窗
      "AMap.PlaceSearch",//地点搜索
      "AMap.Geolocation",//定位到当前位置
      "AMap.Geocoder",//经纬度进行逆地理编码查询
      "AMap.Driving",//驾车导航
      "AMap.Transfer",//公交导航
      "AMap.Walking",//步行导航
      "AMap.Riding",//骑行导航
    ]
  })
    .then((AMap) => {
      // 创建地图实例
      map = new AMap.Map('container', {
        zoom: 11, // 地图显示的缩放级别
        center: [120.6519, 31.3989] // 地图中心点坐标
      });

      // 实例化DrivingSearch
      driving = new AMap.Driving({
        map: map,
         panel: "panel"
      });
      Amap2 = AMap
    })
    .catch(e => {
      console.log(e);
    });
}
const jump = (value) => {
  // 根据起终点经纬度规划驾车导航路线
  console.log('jump', value);
  let start=[120.6519, 31.3989]
  let end=value
  let tu=[120.87,31.27] //途径点
  driving.search(new Amap2.LngLat(start[0],start[1]), new Amap2.LngLat(end[0], end[1]),{
        waypoints:[new Amap2.LngLat(tu[0], tu[1])]
    }, function (status, result) {
    // result即是对应的驾车导航信息
    console.log(status, result);
    if (status === 'complete') {
      console.log('路线规划成功');
    } else {
      console.log('路线规划失败:' + result.info);
    }
  });
}
onMounted(() => {
  getMap()
})

</script>

<style lang="less" scoped>
@color1: blue;

.content {
  width: 100vw;
  height: 600px;
  background-color: @color1;

}

.btnbox {
  display: flex;
  width: 500px;
  justify-content: space-between;
  margin-top: 20px;
  margin-left: 20px;
}

.btn {
  width: 100px;
  height: 50px;
  line-height: 50px;
  background-color: rgb(235, 193, 8);
  text-align: center;
  border-radius: 10px;
  cursor: pointer;
}
#panel{
  width: 400px;
  height: 800px;
  overflow-x: auto;
  position: fixed;
  right: 20px;
  top: 20px;
  // background-color: rgb(255, 255, 255)
}
</style>

### 如何在 Vue 中使用高德地图 API 实现轨迹回放功能 #### 准备工作 为了能够在 Vue 项目中集成使用高德地图的 JS API 来实现轨迹回放,开发者需要先完成一些准备工作。这包括创建一个新的 Vue 应用程序以及注册获取用于调用接口所需的 Key。 #### 安装依赖项 通过命令行工具安装 `vue` 和其他必要的开发环境之后,在项目的根目录下执行如下 npm 命令来引入 axios 或者 fetch 这样的 HTTP 请求库以便后续可以方便地发起网络请求: ```bash npm install axios --save ``` #### 创建组件结构 接下来定义一个名为 AMapPlayback 的单文件 .vue 组件用来承载地图容器及其交互逻辑。该组件内部会初始化地图实例且加载 LBS 数据服务插件以支持路径规划等功能特性[^1]。 #### 初始化地图对象 在 mounted 生命周期钩子函数内利用 script 标签动态注入方式加载外部 js 文件——即官方提供的最新版本的地图 SDK;待其成功载入后再进一步配置 map 变量指向新建立起来的地图实体,设置合适的视图范围参数确保能够完整显示整个行程路线。 ```javascript mounted() { const _this = this; var map, marker; function initAMap() { window._AMapSecurityConfig = { securityJsCode: &#39;your-security-code&#39; }; // 加载高德地图JS API脚本 let script = document.createElement(&#39;script&#39;); script.type = "text/javascript"; script.src = "https://webapi.amap.com/maps?v=2.0&key=" + process.env.VUE_APP_AMAP_KEY; // 使用环境变量存储密钥更安全 script.onload = () => { map = new AMap.Map("container", { zoom: 13, center: [116.397428, 39.90923], // 默认中心坐标可自定义修改 }); // 添加监听事件处理击操作或其他用户行为触发的动作... _this.loadPathData(); }; document.head.appendChild(script); } if (!window.AMap) { initAMap(); } else { setTimeout(() => { initAMap(); }, 0); } } ``` #### 获取绘制行驶线路数据 编写 loadPathData 方法负责向服务器端发送异步请求取得一系列由时间戳和经纬度组成的 GPS 记录列表作为输入源传递给 Polyline 构造器从而形成可视化的折线图形覆盖物展示于画布之上。 ```javascript methods: { async loadPathData() { try { const response = await axios.get(&#39;/path-data&#39;); // 替换成实际的数据接口地址 let path = []; for (let i = 0; i < response.data.length; ++i) { path.push([response.data[i].lng, response.data[i].lat]); } let polyline = new AMap.Polyline({ path: path, strokeColor: "#FF33FF", strokeOpacity: 1, strokeWeight: 6, zIndex: 50, }); polyline.setMap(map); // 设置动画效果使车辆图标沿着既定轨道移动模拟真实行车过程... } catch(error){ console.error(`Error loading path data ${error}`); } }, }, ``` #### 启动播放机制 最后一步就是让小车标志按照预设的速度匀速前进穿过每一个途经直至终位置结束本次演示流程。这里可以通过定时器配合 Marker 类中的 animateAlong 接口轻松达成目标。 ```javascript async playRouteAnimation(){ let carMarkerOptions = { icon: "//a.amap.com/jsapi_demos/static/demo-center-v2/car.png", position: [116.397428, 39.90923], angle: 0, autoRotation : true }; marker = new AMap.Marker(carMarkerOptions ); marker.setMap(map); // 开始沿指定路径运动 marker.animateAlong(path,{ duration : 60 * 1000,// 整体耗时一分钟 repeat : false// 是否循环播放 }); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端_彭于晏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值