|
|
@@ -1,7 +1,10 @@
|
|
|
+<!-- 地图组件:基于高德地图实现 -->
|
|
|
+<!-- TODO @宗超:【设备定位】使用百度地图,和 ercharts 更好集成; -->
|
|
|
<template>
|
|
|
<div v-if="props.isWrite">
|
|
|
<el-form ref="form" label-width="120px">
|
|
|
<el-form-item label="定位位置:">
|
|
|
+ <!-- TODO @TODO @AI:style 改成 unocss -->
|
|
|
<el-select
|
|
|
style="width: 100%"
|
|
|
v-model="state.address"
|
|
|
@@ -41,21 +44,17 @@ import { propTypes } from '@/utils/propTypes'
|
|
|
|
|
|
const emits = defineEmits(['locateChange', 'update:center'])
|
|
|
const state = reactive({
|
|
|
- lonLat: '',
|
|
|
+ lonLat: '', // 经度,纬度
|
|
|
address: '',
|
|
|
loading: false,
|
|
|
- //纬度、经度
|
|
|
- latitude: '',
|
|
|
- longitude: '',
|
|
|
- //地图对象
|
|
|
- map: null as any,
|
|
|
+ latitude: '', // 纬度
|
|
|
+ longitude: '', // 经度
|
|
|
+ map: null as any, // 地图对象
|
|
|
mapAddrOptions: [] as any[],
|
|
|
- //标记对象
|
|
|
- mapMarker: null as any,
|
|
|
+ mapMarker: null as any, // 标记对象
|
|
|
geocoder: null as any,
|
|
|
autoComplete: null as any,
|
|
|
- //搜索提示
|
|
|
- tips: []
|
|
|
+ tips: [] // 搜索提示
|
|
|
})
|
|
|
const props = defineProps({
|
|
|
clickMap: propTypes.bool.def(false),
|
|
|
@@ -69,11 +68,12 @@ const loadMap = () => {
|
|
|
state.address = ''
|
|
|
state.latitude = ''
|
|
|
state.longitude = ''
|
|
|
+ // TODO @AI:可以使用 await 方式么?
|
|
|
AMapLoader.load({
|
|
|
- key: import.meta.env.VITE_AMAP_KEY, // 申请好的Web端开发者Key,首次调用 load 时必填
|
|
|
+ key: import.meta.env.VITE_AMAP_KEY, // 申请好的 Web 端开发者Key,首次调用 load 时必填
|
|
|
version: '2.0', // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
|
|
|
plugins: [
|
|
|
- //逆解析插件
|
|
|
+ // 逆解析插件
|
|
|
'AMap.Geocoder',
|
|
|
'AMap.AutoComplete'
|
|
|
]
|
|
|
@@ -97,15 +97,15 @@ const initMap = () => {
|
|
|
let mapId = props.isWrite ? 'rwMap' : 'rMap'
|
|
|
state.map = new (window as any).AMap.Map(mapId, {
|
|
|
resizeEnable: true,
|
|
|
- zoom: 11, //地图显示的缩放级别
|
|
|
+ zoom: 11, // 地图显示的缩放级别
|
|
|
keyboardEnable: false
|
|
|
})
|
|
|
}
|
|
|
|
|
|
const initGeocoder = () => {
|
|
|
state.geocoder = new (window as any).AMap.Geocoder({
|
|
|
- city: '010', //城市设为北京,默认:“全国”
|
|
|
- radius: 500, //范围,默认:500
|
|
|
+ city: '010', // 城市设为北京,默认:“全国”
|
|
|
+ radius: 500, // 范围,默认:500
|
|
|
extensions: 'all'
|
|
|
})
|
|
|
}
|
|
|
@@ -118,7 +118,8 @@ const initAutoComplete = () => {
|
|
|
}
|
|
|
|
|
|
const autoSearch = (queryValue: string) => {
|
|
|
- state.autoComplete.search(queryValue, (status, result) => {
|
|
|
+ state.autoComplete.search(queryValue, (_status, result) => {
|
|
|
+ // TODO @AI:下面的写法可以优化下么?
|
|
|
var res = result.tips || [] // 搜索成功时,result即是对应的匹配数据
|
|
|
const temp = ref<any[]>([])
|
|
|
res.forEach((p) => {
|
|
|
@@ -133,16 +134,18 @@ const autoSearch = (queryValue: string) => {
|
|
|
})
|
|
|
}
|
|
|
|
|
|
-//添加标记点
|
|
|
+// TODO @AI:方法注释,使用 /** */
|
|
|
+// 添加标记点
|
|
|
const setMarker = (lnglat) => {
|
|
|
+ // TODO @AI: if return 简化下;
|
|
|
if (lnglat) {
|
|
|
+ // 如果点标记已存在则先移除原点
|
|
|
if (state.mapMarker !== null) {
|
|
|
- // 如果点标记已存在则先移除原点
|
|
|
state.map.remove(state.mapMarker)
|
|
|
state.lonLat = ''
|
|
|
}
|
|
|
+ // 定义点标记对象
|
|
|
state.mapMarker = new (window as any).AMap.Marker({
|
|
|
- // 定义点标记对象
|
|
|
position: new (window as any).AMap.LngLat(lnglat[0], lnglat[1])
|
|
|
})
|
|
|
state.map.add(state.mapMarker) // 添加点标记在地图上
|
|
|
@@ -152,9 +155,11 @@ const setMarker = (lnglat) => {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-//经纬度转化为地址、添加标记点
|
|
|
+// TODO @AI:下面的写法可以优化下;例如说:
|
|
|
+// 经纬度转化为地址、添加标记点
|
|
|
const regeoCode = (lonLat) => {
|
|
|
if (lonLat) {
|
|
|
+ // TODO @AI:变量名的拼写;
|
|
|
let lnglat = lonLat.split(',')
|
|
|
state.latitude = lnglat[0]
|
|
|
state.longitude = lnglat[1]
|
|
|
@@ -162,10 +167,10 @@ const regeoCode = (lonLat) => {
|
|
|
emits('update:center', lonLat)
|
|
|
setMarker(lnglat)
|
|
|
getAddress(lnglat)
|
|
|
- console.log('经纬度', lnglat)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+// TODO @AI:代码优化下;
|
|
|
// 把拿到的经纬度转化为地址信息
|
|
|
const getAddress = (lnglat) => {
|
|
|
state.geocoder.getAddress(lnglat, (status, result) => {
|
|
|
@@ -176,14 +181,14 @@ const getAddress = (lnglat) => {
|
|
|
}
|
|
|
})
|
|
|
}
|
|
|
+
|
|
|
// 显式暴露方法,使其可以被父组件访问
|
|
|
-defineExpose({
|
|
|
- regeoCode
|
|
|
-})
|
|
|
+defineExpose({ regeoCode })
|
|
|
|
|
|
onMounted(() => {
|
|
|
loadMap()
|
|
|
})
|
|
|
+// TODO @AI:style 可以改成 unocss 么?
|
|
|
</script>
|
|
|
|
|
|
<style scoped>
|