在vue3项目中使用新版高德地图

Posted 开发那点事儿~

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在vue3项目中使用新版高德地图相关的知识,希望对你有一定的参考价值。

高德开发平台 : 高德开放平台 | 高德地图API (amap.com)

1. 首先你要注册好账号登录

2. 获取key和密钥 

 

自2021年12月02日升级,升级之后所申请的 key 必须配备安全密钥 jscode 一起使用

NPM方式安装和使用(基础版):

        按 NPM 方式安装使用 Loader :

npm i @amap/amap-jsapi-loader --save

        在页面中通过NPM 方式安装的使用 :

<template>
    <div class="app-container">
        <div style="background-color: #ffffff;">
            <div id="container"></div>
        </div>
    </div>
</template>

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

// const map = shallowRef(null);
const path = ref([]);
const current_position = ref([]);

function initMap() 
    window._AMapSecurityConfig = 
        securityJsCode: '8e920f73eb2e6880a92ea6662eefc476',
    
    AMapLoader.load(
        key:"e4e3d44a98350790a1493450032bbec5", // 申请好的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:[113.808299,34.791787], //初始化地图中心点位置
        );
        
    ).catch(e=>
        console.log(e);
    )


    initMap()
</script>

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

</style>

完整代码:

<template>
    <div class="app-container">
        <div style="background-color: #ffffff;">
            <div id="container"></div>
        </div>
    </div>
</template>

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

// const map = shallowRef(null);
const path = ref([]);
const current_position = ref([]);


function initMap() 
    window._AMapSecurityConfig = 
        securityJsCode: '8e920f73eb2e6880a92ea6662eefc476',
    
    AMapLoader.load(
        key:"e4e3d44a98350790a1493450032bbec5", // 申请好的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:[113.808299,34.791787], //初始化地图中心点位置
        );
        // 添加插件
        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);
    )


initMap()
</script>

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

</style>

地图插件效果图:

实例化点标记 :

        第一种方式效果:

         第二种方式效果:

 矢量图 --> 折线:

vue使用高德地图插件-在网页上显示地图

首先在官方平台上进行认证
认证通过之后 进入到我的控制台当中
1.进入到“我的应用”

2.创建一个新应用

3.添加key到你的实例上


4.在项目中引入js 依赖
官方文档的地址:
https://lbs.amap.com/api/javascript-api/guide/abc/prepare


这里就通过最粗暴的方式进行引入 如果有兴趣去了解更多的就去官方文档上去查阅吧!

在您的项目的 index.html 中 引入此链接

<script type="text/javascript">
        window._AMapSecurityConfig = 
            securityJsCode:'您申请的安全密钥',
        
</script>
<script type="text/javascript" src="https://webapi.amap.com/maps?v=1.4.15&key=您申请的key值"></script> 


5.在页面中引入

根据官方文档进行相关的参数的设置 并作用到你定义的容器当中

给你的容器增加点style

<template>
  <!--          测试高德地图-->
  <div>
    <div id="container"></div>
  </div>
</template>

<script>
export default 
  //高德地图
  mounted() 
    var map = new AMap.Map('container',
      zoom:11,
      center: [116.397428,39.90923],
      viewMode: '3D'
    )
  ,
name: "test.vue"

</script>

<style scoped>
#container
  width: 800px;
  height: 500px;
  margin-left: 50%;
  margin-top: 50%;
  transform: translate(-50%,-50%);

</style>

6.效果图:

以上是关于在vue3项目中使用新版高德地图的主要内容,如果未能解决你的问题,请参考以下文章

vue项目使用高德地图

vue3.0+ts使用原生高德地图解决方法

vue3高德地图的下钻方法

vue高德地图 如何一次添加多个点标记到地图实例?

vue使用高德地图和mars3d地图如何切换

Flutter笔记-调用原生IOS高德地图sdk