review:【IoT 物联网】设备位置 review

pull/800/MERGE
YunaiV 2025-07-19 19:59:54 +08:00
parent 4885b34242
commit 3adc2e3f97
1 changed files with 18 additions and 16 deletions

View File

@ -1,4 +1,5 @@
<!-- 地图组件基于百度地图GL实现 --> <!-- 地图组件基于百度地图GL实现 -->
<!-- TODO @super还存在两个没解决的小bug,一个是修改手动定位时一次加载 不知道为何定位点在地图左上角 调了半天没解决 第二个是检索地址确定定位的功能参照百度的文档没也搞好 回头再解决一下 -->
<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">
@ -24,6 +25,7 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="设备地图:"> <el-form-item label="设备地图:">
<!-- TODO @super这里看看 unocss -->
<div id="bdMap" class="mapContainer"></div> <div id="bdMap" class="mapContainer"></div>
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -37,10 +39,10 @@
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { reactive, ref, onMounted } from 'vue' import { reactive, onMounted } from 'vue'
import { propTypes } from '@/utils/propTypes' import { propTypes } from '@/utils/propTypes'
// WindowGL API // Window GL API
declare global { declare global {
interface Window { interface Window {
BMapGL: any BMapGL: any
@ -69,15 +71,13 @@ const props = defineProps({
center: propTypes.string.def('') center: propTypes.string.def('')
}) })
/** /** 加载百度地图 */
* 加载百度地图
*/
const loadMap = () => { const loadMap = () => {
state.address = '' state.address = ''
state.latitude = '' state.latitude = ''
state.longitude = '' state.longitude = ''
// API // API
const script = document.createElement('script') const script = document.createElement('script')
script.src = `https://api.map.baidu.com/api?v=1.0&type=webgl&ak=${ script.src = `https://api.map.baidu.com/api?v=1.0&type=webgl&ak=${
import.meta.env.VITE_BAIDU_MAP_KEY import.meta.env.VITE_BAIDU_MAP_KEY
@ -90,6 +90,7 @@ const loadMap = () => {
initGeocoder() initGeocoder()
initAutoComplete() initAutoComplete()
// TODO @super
if (props.clickMap) { if (props.clickMap) {
state.map.addEventListener('click', (e: any) => { state.map.addEventListener('click', (e: any) => {
console.log(e) console.log(e)
@ -101,18 +102,18 @@ const loadMap = () => {
}) })
} }
// TODO @super
if (props.center) { if (props.center) {
regeoCode(props.center) regeoCode(props.center)
} }
} }
} }
/** /** 初始化地图 */
* 初始化地图
*/
const initMap = () => { const initMap = () => {
const mapId = 'bdMap' const mapId = 'bdMap'
state.map = new window.BMapGL.Map(mapId) state.map = new window.BMapGL.Map(mapId)
// TODO @super
state.map.centerAndZoom(new window.BMapGL.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()
@ -123,16 +124,12 @@ const initMap = () => {
state.map.addControl(new window.BMapGL.ZoomControl()) state.map.addControl(new window.BMapGL.ZoomControl())
} }
/** /** 初始化地理编码器 */
* 初始化地理编码器
*/
const initGeocoder = () => { const initGeocoder = () => {
state.geocoder = new window.BMapGL.Geocoder() state.geocoder = new window.BMapGL.Geocoder()
} }
/** /** 初始化自动完成 */
* 初始化自动完成
*/
const initAutoComplete = () => { const initAutoComplete = () => {
state.autoComplete = new window.BMapGL.Autocomplete({ state.autoComplete = new window.BMapGL.Autocomplete({
input: 'searchInput', input: 'searchInput',
@ -192,6 +189,7 @@ const handleAddressSelect = (value: string) => {
* 添加标记点 * 添加标记点
* @param lnglat 经纬度数组 * @param lnglat 经纬度数组
*/ */
// TODO @super idea 绿
const setMarker = (lnglat: any) => { const setMarker = (lnglat: any) => {
if (!lnglat) return if (!lnglat) return
@ -214,9 +212,11 @@ const setMarker = (lnglat: any) => {
* 经纬度转化为地址添加标记点 * 经纬度转化为地址添加标记点
* @param lonLat 经度,纬度字符串 * @param lonLat 经度,纬度字符串
*/ */
// TODO @super idea 绿
const regeoCode = (lonLat: string) => { const regeoCode = (lonLat: string) => {
if (!lonLat) return if (!lonLat) return
// TODO @super idea 绿
const lnglat = lonLat.split(',') const lnglat = lonLat.split(',')
if (lnglat.length !== 2) return if (lnglat.length !== 2) return
@ -236,8 +236,10 @@ const regeoCode = (lonLat: string) => {
getAddress(lnglat) getAddress(lnglat)
} }
// TODO @superlnglat
/** /**
* 根据经纬度获取地址信息 * 根据经纬度获取地址信息
*
* @param lnglat 经纬度数组 * @param lnglat 经纬度数组
*/ */
const getAddress = (lnglat: any) => { const getAddress = (lnglat: any) => {
@ -263,4 +265,4 @@ onMounted(() => {
width: 100%; width: 100%;
height: 400px; height: 400px;
} }
</style> </style>