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

简介: 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高德地图实现

到这里也就结束了,记得点赞哦。


相关文章
|
22天前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
126 64
|
22天前
|
JavaScript 前端开发 API
Vue 3 中 v-model 与 Vue 2 中 v-model 的区别是什么?
总的来说,Vue 3 中的 `v-model` 在灵活性、与组合式 API 的结合、对自定义组件的支持等方面都有了明显的提升和改进,使其更适应现代前端开发的需求和趋势。但需要注意的是,在迁移过程中可能需要对一些代码进行调整和适配。
101 60
|
22天前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
28 8
|
21天前
|
存储 JavaScript 数据管理
除了provide/inject,Vue3中还有哪些方式可以避免v-model的循环引用?
需要注意的是,在实际开发中,应根据具体的项目需求和组件结构来选择合适的方式来避免`v-model`的循环引用。同时,要综合考虑代码的可读性、可维护性和性能等因素,以确保系统的稳定和高效运行。
21 1
|
21天前
|
JavaScript
Vue3中使用provide/inject来避免v-model的循环引用
`provide`和`inject`是 Vue 3 中非常有用的特性,在处理一些复杂的组件间通信问题时,可以提供一种灵活的解决方案。通过合理使用它们,可以帮助我们更好地避免`v-model`的循环引用问题,提高代码的质量和可维护性。
32 1
|
22天前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。
|
1月前
|
JavaScript 索引
Vue 3.x 版本中双向数据绑定的底层实现有哪些变化
从Vue 2.x的`Object.defineProperty`到Vue 3.x的`Proxy`,实现了更高效的数据劫持与响应式处理。`Proxy`不仅能够代理整个对象,动态响应属性的增删,还优化了嵌套对象的处理和依赖追踪,减少了不必要的视图更新,提升了性能。同时,Vue 3.x对数组的响应式处理也更加灵活,简化了开发流程。
|
1月前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
59 1
|
25天前
|
JavaScript 前端开发 API
从Vue 2到Vue 3的演进
从Vue 2到Vue 3的演进
37 0
|
25天前
|
JavaScript 前端开发 API
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
54 0