feat:map2

pull/794/head
alwayssuper 2025-07-19 16:55:10 +08:00
parent dffedc9840
commit ea3fa161ec
1 changed files with 46 additions and 32 deletions

View File

@ -1,4 +1,4 @@
<!-- 地图组件基于百度地图实现 --> <!-- 地图组件基于百度地图GL实现 -->
<template> <template>
<div v-if="props.isWrite"> <div v-if="props.isWrite">
<el-form ref="form" label-width="120px"> <el-form ref="form" label-width="120px">
@ -40,6 +40,14 @@
import { reactive, ref, onMounted } from 'vue' import { reactive, ref, onMounted } from 'vue'
import { propTypes } from '@/utils/propTypes' import { propTypes } from '@/utils/propTypes'
// WindowGL API
declare global {
interface Window {
BMapGL: any
initBaiduMap: () => void
}
}
const emits = defineEmits(['locateChange', 'update:center']) const emits = defineEmits(['locateChange', 'update:center'])
const state = reactive({ const state = reactive({
lonLat: '', // , lonLat: '', // ,
@ -71,7 +79,9 @@ const loadMap = () => {
// API // API
const script = document.createElement('script') const script = document.createElement('script')
script.src = `https://api.map.baidu.com/api?v=3.0&ak=${import.meta.env.VITE_BAIDU_MAP_KEY}&callback=initBaiduMap` script.src = `https://api.map.baidu.com/api?v=1.0&type=webgl&ak=${
import.meta.env.VITE_BAIDU_MAP_KEY
}&callback=initBaiduMap`
document.body.appendChild(script) document.body.appendChild(script)
// //
@ -82,8 +92,11 @@ const loadMap = () => {
if (props.clickMap) { if (props.clickMap) {
state.map.addEventListener('click', (e: any) => { state.map.addEventListener('click', (e: any) => {
const point = e.point console.log(e)
const point = e.latlng
console.log(point)
state.lonLat = point.lng + ',' + point.lat state.lonLat = point.lng + ',' + point.lat
console.log(state.lonLat)
regeoCode(state.lonLat) regeoCode(state.lonLat)
}) })
} }
@ -99,29 +112,30 @@ const loadMap = () => {
*/ */
const initMap = () => { const initMap = () => {
const mapId = 'bdMap' const mapId = 'bdMap'
state.map = new window.BMap.Map(mapId) state.map = new window.BMapGL.Map(mapId)
state.map.centerAndZoom(new window.BMap.Point(116.404, 39.915), 11) state.map.centerAndZoom(new window.BMapGL.Point(116.404, 39.915), 11)
state.map.enableScrollWheelZoom() state.map.enableScrollWheelZoom()
state.map.disableDoubleClickZoom() state.map.disableDoubleClickZoom()
// //
state.map.addControl(new window.BMap.NavigationControl()) state.map.addControl(new window.BMapGL.NavigationControl())
state.map.addControl(new window.BMap.ScaleControl()) state.map.addControl(new window.BMapGL.ScaleControl())
state.map.addControl(new window.BMapGL.ZoomControl())
} }
/** /**
* 初始化地理编码器 * 初始化地理编码器
*/ */
const initGeocoder = () => { const initGeocoder = () => {
state.geocoder = new window.BMap.Geocoder() state.geocoder = new window.BMapGL.Geocoder()
} }
/** /**
* 初始化自动完成 * 初始化自动完成
*/ */
const initAutoComplete = () => { const initAutoComplete = () => {
state.autoComplete = new window.BMap.Autocomplete({ state.autoComplete = new window.BMapGL.Autocomplete({
input: "searchInput", input: 'searchInput',
location: state.map location: state.map
}) })
} }
@ -139,7 +153,7 @@ const autoSearch = (queryValue: string) => {
state.loading = true state.loading = true
// 使 // 使
const localSearch = new window.BMap.LocalSearch(state.map, { const localSearch = new window.BMapGL.LocalSearch(state.map, {
onSearchComplete: (results: any) => { onSearchComplete: (results: any) => {
state.loading = false state.loading = false
const temp: any[] = [] const temp: any[] = []
@ -188,8 +202,8 @@ const setMarker = (lnglat: any) => {
} }
// //
const point = new window.BMap.Point(lnglat[0], lnglat[1]) const point = new window.BMapGL.Point(lnglat[0], lnglat[1])
state.mapMarker = new window.BMap.Marker(point) state.mapMarker = new window.BMapGL.Marker(point)
// //
state.map.addOverlay(state.mapMarker) state.map.addOverlay(state.mapMarker)
@ -223,7 +237,7 @@ const regeoCode = (lonLat: string) => {
* @param lnglat 经纬度数组 * @param lnglat 经纬度数组
*/ */
const getAddress = (lnglat: any) => { const getAddress = (lnglat: any) => {
const point = new window.BMap.Point(lnglat[0], lnglat[1]) const point = new window.BMapGL.Point(lnglat[0], lnglat[1])
state.geocoder.getLocation(point, (result: any) => { state.geocoder.getLocation(point, (result: any) => {
if (result && result.address) { if (result && result.address) {