vue3使用高德地图实现3d地图

vue3实现高德地图

1.没有高德地图的朋友们可以去高德地图Api注册账号
注册账号

2.注册之后进入高德开发平台,点击应用管理下的我的应用
在这里插入图片描述
3.如果以前有创建过应用就不用重新创建,如果没有,则需要新建一个应用
在这里插入图片描述
4.创建完毕后,可以看到我们所需要的key和密钥,在后续代码中有用到
在这里插入图片描述
5.在vue3项目中下载loader

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

6.到这里就该写代码了
首先定义容器

<template>
    <div>
        <van-nav-bar title="地图容器" left-text="" left-arrow @click-left="onClickLeft" />
    </div>
    <div class="app-container">
        <div style="background-color: #ffffff;">
            <div id="mapcontainer"></div>
        </div>
    </div>
</template>

在下面script内配置所需的key和密匙

window._AMapSecurityConfig = {
        securityJsCode: 'caa87ea25d73c26ecbd5ffa08767bbd1',
    }
    AMapLoader.load({
        key: "自己创建的key", // 创建申请好的key,必填
        version: "2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
    }).then((AMap) => {
        const map = new AMap.Map("container", {  //设置地图容器id
            viewMode: "3D",    //是否为3D地图模式
            zoom: 13,           //初始化地图级别
            center: [115.493706, 38.880989], //初始化地图中心点位置(可以自己设置)
        });

可以添加插件

// 添加插件
        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) => {
    // 获取点击位置的经度和纬度
    const lng = e.lnglat.lng; // 经度值
    const lat = e.lnglat.lat; // 纬度值
    // 将当前位置的经纬度值赋给current_position变量
    current_position.value = [lng, lat];
    // 将当前位置的经纬度值添加到path数组中
    path.value.push([lng, lat]);
    
});

实例化点标记
(1)第一种方式就是封装成函数来触发

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(-30, -60),
            });
            marker.setMap(map);
        }

(2)可以把position的经纬度值写成死的

const marker = new AMap.Marker({
            icon: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png",
            position: [115.493706, 38.880989],
            // 通过设置 offset 来添加偏移量
            offset: new AMap.Pixel(-30, -60),
        });
        marker.setMap(map);

最后完整代码奉上

<template>
    <div>
        <van-nav-bar title="地图容器" left-text="" left-arrow @click-left="onClickLeft" />
    </div>
    <div class="app-container">
        <div style="background-color: #ffffff;">
            <div id="mapcontainer"></div>
        </div>
    </div>
</template>
 
<script setup>
import AMapLoader from '@amap/amap-jsapi-loader';
//在Vue3中使用时,需要引入Vue3中的shallowRef方法(使用shallowRef进行非深度监听
import { shallowRef } from '@vue/reactivity';
import { ref } from "vue";

// const map = shallowRef(null);
const onClickLeft = () => history.back(); //返回上一个页面
const path = ref([]);
const current_position = ref([]);


function initMap() {
    window._AMapSecurityConfig = {
        securityJsCode: '自己创建的密匙',自己创建的密匙
    }
    AMapLoader.load({
        key: "自己创建的key", // 自己申请的key,必填
        version: "2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
    }).then((AMap) => {
        const map = new AMap.Map("mapcontainer", {  //设置地图容器id
            viewMode: "3D",    //是否为3D地图模式
            zoom: 13,           //初始化地图级别
            center: [115.493706, 38.880989], //初始化地图中心点位置
        });
        // 添加插件
        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) => {
		    // 获取点击位置的经度和纬度
		    const lng = e.lnglat.lng; // 经度值
		    const lat = e.lnglat.lat; // 纬度值
		    // 将当前位置的经纬度值赋给current_position变量
		    current_position.value = [lng, lat];
		    // 将当前位置的经纬度值添加到path数组中
		    path.value.push([lng, lat]);
    
		});


        // 实例化点标记
        // 第一种(封成函数来触发)
        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(-30, -60),
            });
            marker.setMap(map);
        }

    }).catch(e => {
        console.log(e);
    })
}

initMap()
</script>
 
<style>
#mapcontainer{
    width: 100%;
    height: 30rem;
}
</style>

效果视频奉上

vue3高德地图实现

到这里也就结束了,记得点赞哦。
在这里插入图片描述

Vue 3D 卫星高德地图实现通常需要结合Vue.js的组件化思想以及一些地图API库,如AMap Vue。以下是简单的步骤: 1. **安装依赖**: 首先,你需要安装`@vue-amap/core`和`@vue-amap/satellite`这两个官方推荐的Amap Vue插件。你可以使用npm或yarn进行安装: ``` npm install @vue-amap/core @vue-amap/satellite ``` 2. **设置环境变量**: 在项目配置文件(例如`.env`或`config.js`)中添加阿里的Map API Key。 3. **创建组件**: 创建一个新的Vue组件,并引入相关的import语句,如`Amap`和`SatelliteLayer`: ```html <template> <div ref="container" :style="{ width: &#39;100%&#39;, height: &#39;100%&#39; }"></div> </template> <script> import { Amap, SatelliteLayer } from &#39;@vue-amap/core&#39;; export default { components: { Amap, // 使用自定义名称避免冲突 MySatelliteLayer: SatelliteLayer }, data() { return { map: null }; }, mounted() { this.initMap(); }, methods: { initMap() { this.map = new Amap({ zoom: 13, // 初始缩放级别 center: [116.404, 39.915], // 北京坐标 mapType: &#39;satellite&#39;, // 地图类型,此处为卫星模式 }); this.mySatelliteLayer = new MySatelliteLayer(); // 初始化卫星图层 this.map.addLayer(this.mySatelliteLayer); // 添加到地图上 } } }; </script> ``` 4. **样式调整**: 为了让你的地图适应容器大小,可以使用CSS来自动调整高度和宽度。 5. **运行组件**: 将这个组件挂载到需要显示3D卫星地图的部分。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值