97 lines
2.4 KiB
97 lines
2.4 KiB
3 years ago
|
import store from '/@/store'
|
||
|
import { getRoot } from '/@/root'
|
||
|
import { ELocalStorageKey } from '/@/types'
|
||
|
import { getDeviceBySn } from '/@/api/manage'
|
||
|
import { message } from 'ant-design-vue'
|
||
|
|
||
|
export function deviceTsaUpdate () {
|
||
|
const root = getRoot()
|
||
|
const AMap = root.$aMapObj
|
||
|
|
||
|
const map = root.$aMap
|
||
|
const icons: {
|
||
|
[key: string]: string
|
||
|
} = {
|
||
|
'sub-device' : '/@/assets/icons/drone.png',
|
||
|
'gateway': '/@/assets/icons/rc.png',
|
||
|
'dock': '/@/assets/icons/dock.png'
|
||
|
}
|
||
|
const markers = store.state.markerInfo.coverMap
|
||
|
const paths = store.state.markerInfo.pathMap
|
||
|
|
||
|
const passedPolyline = new AMap.Polyline({
|
||
|
map: map,
|
||
|
strokeColor: '#939393' // 线颜色
|
||
|
})
|
||
|
|
||
|
function initIcon (type: string) {
|
||
|
return new AMap.Icon({
|
||
|
image: icons[type],
|
||
|
imageSize: new AMap.Size(40, 40)
|
||
|
})
|
||
|
}
|
||
|
|
||
|
function initMarker (type: string, name: string, sn: string, lng?: number, lat?: number) {
|
||
|
if (markers[sn]) {
|
||
|
return
|
||
|
}
|
||
|
markers[sn] = new AMap.Marker({
|
||
|
position: new AMap.LngLat(lng ? lng : 113.935913, lat ? lat : 22.525335),
|
||
|
icon: initIcon(type),
|
||
|
title: name,
|
||
|
anchor: 'top-center',
|
||
|
offset: [0, -20],
|
||
|
})
|
||
|
root.$aMap.add(markers[sn])
|
||
|
|
||
|
// markers[sn].on('moving', function (e: any) {
|
||
|
// let path = paths[sn]
|
||
|
// if (!path) {
|
||
|
// paths[sn] = e.passedPath
|
||
|
// return
|
||
|
// }
|
||
|
// path.push(e.passedPath[0])
|
||
|
// path.push(e.passedPath[1])
|
||
|
// passedPolyline.setPath(path)
|
||
|
// })
|
||
|
}
|
||
|
function removeMarker (sn: string) {
|
||
|
if (!markers[sn]) {
|
||
|
return
|
||
|
}
|
||
|
root.$aMap.remove(markers[sn])
|
||
|
passedPolyline.setPath([])
|
||
|
delete markers[sn]
|
||
|
delete paths[sn]
|
||
|
}
|
||
|
function addMarker(sn: string, lng?: number, lat?: number) {
|
||
|
getDeviceBySn(localStorage.getItem(ELocalStorageKey.WorkspaceId)!, sn)
|
||
|
.then(data => {
|
||
|
if (data.code !== 0) {
|
||
|
message.error(data.message)
|
||
|
return
|
||
|
}
|
||
|
initMarker(data.data.domain, data.data.nickname, sn, lng, lat)
|
||
|
})
|
||
|
}
|
||
|
function moveTo(sn: string, lng: number, lat: number) {
|
||
|
let marker = markers[sn]
|
||
|
if (!marker) {
|
||
|
addMarker(sn, lng, lat)
|
||
|
marker = markers[sn]
|
||
|
return
|
||
|
}
|
||
|
marker.moveTo([lng, lat], {
|
||
|
duration: 1800,
|
||
|
autoRotation: true
|
||
|
})
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
marker: markers,
|
||
|
initMarker,
|
||
|
removeMarker,
|
||
|
moveTo
|
||
|
}
|
||
|
}
|