vue3接入高德地图

1,准备工作

注册高德,注册成功后,进入控制台,创建应用,并添加key

添加key的时候选择web端(js api)

2,安装依赖

npm install @amap/amap-jsapi-loader

pnpm add @amap/amap-jsapi-loader

yarn add @amap/amap-jsapi-loader

根据自己实际情况,选择npm,pnpm或者yarn

3,创建Map组件

<template>
  <Dialog :title="dialogTitle" v-model="dialogVisible" width="50%">
  <div class="app-container">
    <div style="background-color: #ffffff;">
      <div id="container"></div>
    </div>
  </div>
  </Dialog>
</template>

<script setup>
import AMapLoader from '@amap/amap-jsapi-loader';
/*在Vue3中使用时,需要引入Vue3中的shallowRef方法(使用shallowRef进行非深度监听,
因为在Vue3中所使用的Proxy拦截操作会改变JSAPI原生对象,所以此处需要区别Vue2使用方式对地图对象进行非深度监听,
否则会出现问题,建议JSAPI相关对象采用非响应式的普通对象来存储)*/
import { shallowRef } from 'vue'
import {ref} from "vue";
const dialogVisible = ref(false)
const dialogTitle = ref('地图')
// const map = shallowRef(null);
const path = ref([]);
const current_position = ref([]);
const open = () => {
  initMap()
  dialogVisible.value = true
}
defineExpose({ open })

const initMap =() =>{
  window._AMapSecurityConfig = {
    securityJsCode: '12',
  }
  AMapLoader.load({
    key:"34", // 申请好的Web端开发者Key,首次调用 load 时必填
    version:"2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
    // plugins:[''], // 需要使用的的插件列表,如比例尺'AMap.Scale'等
  }).then((AMap)=>{
    const map = new AMap.Map("container",{  //设置地图容器id
      viewMode:"3D",    //是否为3D地图模式
      zoom:13,           //初始化地图级别
      center:[117.120000,36.650200], //初始化地图中心点位置
    });
    // 添加插件
    AMap.plugin(["AMap.ToolBar", "AMap.Scale", "AMap.HawkEye","AMap.Geolocation","AMap.MapType","AMap.MouseTool"], function () {
      //异步同时加载多个插件
      // 添加地图插件
      map.addControl(new AMap.ToolBar()); // 工具条控件;范围选择控件
      map.addControl(new AMap.Scale()); // 显示当前地图中心的比例尺
      map.addControl(new AMap.HawkEye()); // 显示缩略图
      map.addControl(new AMap.Geolocation()); // 定位当前位置
      map.addControl(new AMap.MapType()); // 实现默认图层与卫星图,实时交通图层之间切换

      // 以下是鼠标工具插件
      const mouseTool = new AMap.MouseTool(map);
      // mouseTool.rule();// 用户手动绘制折线图,测量距离
      mouseTool.measureArea(); // 测量面积
    });
    // 单击
    map.on('click',(e) => {
      // lng ==> 经度值  lat => 维度值
      current_position.value = [e.lnglat.lng,e.lnglat.lat];
      path.value.push([e.lnglat.lng,e.lnglat.lat]);
      // addMarker();
      // addPolyLine();
    })


    // 实例化点标记
    // 第一种(封成函数来触发)
    function addMarker() {
      const marker = new AMap.Marker({
        icon: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png",
        position: current_position.value, // 这里我们通过上面的点击获取经纬度坐标,实时添加标记
        // 通过设置 offset 来添加偏移量
        offset: new AMap.Pixel(-26, -54),
      });
      marker.setMap(map);
    }
    // 第二种 直接写死 position 的经纬度值
    /*const marker = new AMap.Marker({
        icon: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png",
        position: [113.808299,34.791787],
        // 通过设置 offset 来添加偏移量
        offset: new AMap.Pixel(-26, -54),
    });
    marker.setMap(map);*/


    // 折线
    function addPolyLine() {
      const polyline = new AMap.Polyline({
        path: path.value,
        isOutline: true,
        outlineColor: "#ffeeff",
        borderWeight: 1,
        strokeColor: "#3366FF",
        strokeOpacity: 0.6,
        strokeWeight: 5,
        // 折线样式还支持 'dashed'
        strokeStyle: "solid",
        // strokeStyle是dashed时有效
        // strokeDasharray: [10, 5],
        lineJoin: "round",
        lineCap: "round",
        zIndex: 50,
      });
      map.add([polyline]);
    }



  }).catch(e=>{
    console.log(e);
  })
}
// /** 初始化 **/
// onMounted(() => {
//   initMap()
// })

</script>

<style>
#container{
  padding:0px;
  margin: 0px;
  width: 100%;
  height: 800px;
}
</style>

4,加载

在需要调用的地方引入vue

<GMap ref="mapRef"></GMap>

我这是通过点击事件弹出地图的

const mapRef = ref()
const showMap = () => {
  mapRef.value.open()
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值