vue3 地图(天地图,百度地图,腾讯地图,高德地图)封装组件调用 带地图搜索功能

news/2025/1/13 17:45:18/文章来源:https://www.cnblogs.com/sws-kevin/p/18396320
<template><!-- 地图 --><div class="container w"><div id="map" class="map radius-md" :style="{ width: width, height: height }"></div></div>
</template>
<script>
import { commonStore } from '@/store';
export default defineComponent({props: {modelValue: {type: String,default: '上海市黄浦区上海中心大厦',},// 是否可拖拽draggable: {type: Boolean,default: true,},width: {type: String,default: '100%',},height: {type: String,default: '350px',},type: {type: String,default: 'baidu', // 地图类型 默认1.tianditu天地图/2.baidu百度地图/3.tencent腾讯地图/4.amap高德地图},},emits: ['point'],setup(props, context) {const common_store = commonStore();const common_amap_map_ak = common_store.common.config.common_amap_map_ak;const common_amap_map_safety_ak = common_store.common.config.common_amap_map_safety_ak;const common_baidu_map_ak = common_store.common.config.common_baidu_map_ak;const common_tencent_map_ak = common_store.common.config.common_tencent_map_ak;const common_tianditu_map_ak = common_store.common.config.common_tianditu_map_ak;const map = ref(null);const lng = ref(121.47894);const lat = ref(31.223);watch(() => props.modelValue,(val) => {if (!val) return;map_event(val);});onMounted(() => {load_map_script(); // 加载地图资源});const load_map_script = () => {// 此处在所需页面引入资源就是,不用再public/index.html中引入let script = document.createElement('script');script.type = 'text/javascript';script.className = 'loadmap'; // 给script一个类名if (props.type === '1') {// 天地图script.src = `https://api.tianditu.gov.cn/api?v=4.0&tk=${common_tianditu_map_ak || 'bf0676d6b99ee6f7f917640a54af0415'}`;} else if (props.type === '2') {// 百度地图script.src = `https://api.map.baidu.com/getscript?v=3.0&ak=${common_baidu_map_ak || 'XSdiGjfg3wOHiKjpYEMG6CYA'}`;} else if (props.type === '3') {// 腾讯地图script.src = `https://map.qq.com/api/js?v=2.exp&key=${common_tencent_map_ak || 'IMYBZ-QJ6C3-QPZ3Y-OUKL6-IVU5S-ZYBKA'}&callback=init`;} else if (props.type === '4') {// 高德地图script.src = `https://webapi.amap.com/maps?v=2.0&key=${common_amap_map_ak || '3e92c6bfdd5ddb4aac39ed5e4d0db663'}`;}// 使用script.onload,待资源加载完成,再初始化地图if (props.type === '3') {window.init = () => {init();};load_tx_map();} else {script.onload = () => {init();};}let loadmap = document.getElementsByClassName('loadmap');if (loadmap) {// 每次append script之前判断一下,避免重复添加script资源标签for (var i = 0; i < loadmap.length; i++) {document.body.removeChild(loadmap[i]);}}if (props.type === '4') {window._AMapSecurityConfig = {securityJsCode: common_amap_map_safety_ak || '6d68c17c7b2a96a0616b1b8c371f391f',};}document.body.appendChild(script);};const load_tx_map = () => {// 此处在所需页面引入资源就是,不用再public/index.html中引入let script = document.createElement('script');script.type = 'text/javascript';script.className = 'loadmap2'; // 给script一个类名script.src = 'https://map.qq.com/api/gljs?v=1.exp&key=IMYBZ-QJ6C3-QPZ3Y-OUKL6-IVU5S-ZYBKA&libraries=service';let loadmap2 = document.getElementsByClassName('loadmap2');if (loadmap2) {// 每次append script之前判断一下,避免重复添加script资源标签for (var i = 0; i < loadmap2.length; i++) {document.body.removeChild(loadmap2[i]);}}document.body.appendChild(script);};// 初始化地图const init = () => {switch (props.type) {case '1':const T = window.T;// 坐标map.value = new T.Map('map');let point = new T.LngLat(lng.value, lat.value);map.value.centerAndZoom(point, 10);// 禁止鼠标滚动缩小放大map.value.disableScrollWheelZoom();// 添加控件//创建缩放平移控件对象let control = new T.Control.Zoom();// control.setPosition(T_ANCHOR_TOP_RIGHT);//添加缩放平移控件map.value.addControl(control);map.value.clearOverLays();let marker = new T.Marker(point);map.value.addOverLay(marker);if (props.draggable) {marker.enableDragging();marker.addEventListener('dragend', function (e) {map.value.panTo(new T.LngLat(e.lnglat.lng, e.lnglat.lat));lat.value = e.lnglat.lat;lng.value = e.lnglat.lng;context.emit('point', lng, lat);});}break;case '2':const BMap = window.BMap;map.value = new BMap.Map('map', {enableMapClick: false,});let point2 = new BMap.Point(lng.value, lat.value);map.value.centerAndZoom(point2, 10); // 初始化地图,设置中心点坐标和地图级别// 添加控件let navigationControl = new BMap.NavigationControl({// 靠左上角位置anchor: window.BMAP_ANCHOR_TOP_LEFT,// LARGE类型type: window.BMAP_NAVIGATION_CONTROL_LARGE,});map.value.addControl(navigationControl);let marker2 = new BMap.Marker(point2);map.value.addOverlay(marker2);if (props.draggable) {// 修正marker的初始化marker2.enableDragging();marker2.addEventListener('dragend', function (e) {map.value.panTo(e.point);lat.value = e.point.lat;lng.value = e.point.lng;context.emit('point', lng, lat);});// 设置标注提示信息let cr = new BMap.CopyrightControl({ anchor: window.BMAP_ANCHOR_BOTTOM_RIGHT });map.value.addControl(cr); //添加版权控件let bs = map.value.getBounds(); //返回地图可视区域cr.addCopyright({ id: 1, content: '<div class="map-dragging-tips"><span>' + '拖动红色图标直接定位' + '</span></div>', bounds: bs });}break;case '3':const qq_maps = window.qq.maps;let point3 = new qq_maps.LatLng(lat.value, lng.value);map.value = new qq_maps.Map('map', {center: point3,zoom: 10,});let marker3 = new qq_maps.Marker({map: map.value,position: point3,draggable: props.draggable,});qq_maps.event.addListener(marker3, 'dragend', function (e) {lat.value = e.latLng.lat;lng.value = e.latLng.lng;map.value.panTo(e.latLng);context.emit('point', lng, lat);});break;case '4':const AMap = window.AMap;map.value = new AMap.Map('map', {zoomEnable: true,resizeEnable: false,scrollWheel: false,zoom: 10, // 初始化地图级别center: [lng.value, lat.value], // 初始化地图中心点位置});AMap.plugin(['AMap.ToolBar'], function () {// 在图面添加工具条控件, 工具条控件只有缩放功能map.value.addControl(new AMap.ToolBar());});// 创建标注var marker_config = {position: map.value.getCenter(),// offset: new AMap.Pixel(-13, -30),draggable: props.draggable,};let marker4 = new AMap.Marker(marker_config);marker4.setMap(map);// 标注可拖拽回调if (props.draggable) {marker4.on('dragend', (e) => {map.value.panTo(e.lnglat);lng.value = e.lnglat.lng;lat.value = e.lnglat.lat;context.emit('point', lng.value, lat.value);});}map.value.add(marker4);break;}};const map_event = (value) => {switch (props.type) {case '1':let geo = new T.Geocoder();geo.getPoint(value, function (result) {let point = result.getLocationPoint();if (result.getStatus() == 0) {lng.value = point.lng;lat.value = point.lat;init();map.value.panTo(new T.LngLat(lng.value, lat.value));context.emit('point', lng.value, lat.value);} else {ElMessage.info(point?.getMsg() || '您选择地址没有解析到结果!');}});break;case '2':// 创建地址解析器实例let geo2 = new window.BMap.Geocoder();// 将地址解析结果显示在地图上,并调整地图视野geo2.getPoint(value,function (point) {if (point) {lng.value = point.lng;lat.value = point.lat;context.emit('point', lng.value, lat.value);init();} else {ElMessage.info(point?.getMsg() || '您选择地址没有解析到结果!');}},'全国');break;case '3':let geo3 = new TMap.service.Geocoder();geo3.getLocation({ address: value }).then((result) => {let lnglat = result.result.location;lng.value = lnglat.lng;lat.value = lnglat.lat;init();context.emit('point', lng.value, lat.value);});break;case '4':AMap.plugin('AMap.Geocoder', () => {new AMap.Geocoder().getLocation(value, (status, result) => {if (status === 'complete' && result.geocodes.length) {var lnglat = result.geocodes[0].location;lng.value = lnglat.lng;lat.value = lnglat.lat;init();context.emit('point', lng.value, lat.value);} else {ElMessage.info('您选择地址没有解析到结果!');}});});break;}};},
});
</script>
<style lang="scss" scoped></style>

组件调用及回调:

<maps v-model="map_address" :type="common_map_type" @point="map_point"></maps>

// 参数:
// 地址
const map_address = ref('');
// 地图类型
const map_type = ref('tianditu');
//地图用于回调用于获取坐标
const map_point = (lng: number, lat: number) => {form.lng = lng;form.lat = lat; };
 
 地图效果展示:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/792097.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【优技教育】Oracle 19c OCP 082题库(第8题)- 2024年修正版

【优技教育】Oracle 19c OCP 082题库(Q 8题)- 2024年修正版 考试科目:1Z0-082 考试题量:90 通过分数:60% 考试时间:150min 本文为(CUUG 原创)整理并解析,转发请注明出处,禁止抄袭及未经注明出处的转载。 原文地址:http://www.cuug.com.cn/ocp/082kaoshitiku/38167699730…

【FMC129】基于VITA57.1标准的JESD204B接口8通道125MSPS 16位AD采集子卡模块

板卡概述FMC129是一款8通道125MHz采样率16位AD采集FMC子卡,符合VITA57.1规范,可以作为一个理想的IO模块耦合至FPGA前端,8通道AD通过高带宽的FMC连接器(HPC)连接至FPGA从而大大降低了系统信号延迟。该板卡支持板上可编程采样时钟和外部参考时钟以及采样时钟,多片板卡还可以…

Chrome 浏览器插件获取网页 window 对象(方案一)

最近有个需求,是在浏览器插件中获取 window 对象下的某个数据,当时觉得很简单,和 document 一样,直接通过嵌入 content_scripts 直接获取,然后使用 sendMessage 发送数据到插件就行了,结果发现不是这样滴...前言 最近有个需求,是在浏览器插件中获取 window 对象下的某个…

1.项目目录

1.AppScope 全局公共资源(常量、图片)存放路径 2.entry 工程模块(开发)目录 3.hvigor 基于ts实现的前端构建和任务编程的工具(npm) 4.oh_modules 依赖包 5.build-profile.json5 项目级别的配置信息 6.local.properties 本地基本信息 7.oh-package.json5 依赖关系配置和基…

代码随想录day50 || 图论基础

图论 基础定义图的构造方式 1,邻接矩阵矩阵位置array[i][j] = k, i表示节点i,j表示节点j,[i][j] 表示i-->j存在一条边,k表示的是边的权重邻接矩阵的优点: 表达方式简单,易于理解 检查任意两个顶点间是否存在边的操作非常快 适合稠密图,在边数接近顶点数平方的图中,邻…