yak_handcuffs/src/views/monitoringCenter/deviceLocationMap.vue

72 lines
1.7 KiB
Vue
Raw Normal View History

2025-04-25 18:23:20 +08:00
<template>
<div class="monitoringMap" id="mapcontainer"></div>
<div :style="{ display: 'none' }">
<InfoWindow class="infoBox" :value="locationInfo" @close="InfoWin.close()" />
</div>
</template>
<script lang="ts" setup>
import { locateRecord } from "@/api";
import { format } from "@/utils";
import { MapCustom } from "@/utils/mapCustom";
import { onMounted, ref, watch } from "vue";
import InfoWindow from "@/components/InfoWindow.vue";
import location from "@/assets/img/location.png";
let InfoWin = null;
let newMap = null;
let locationInfo = ref({});
const props = defineProps({
deviceId: {
type: String || Number,
default: "",
},
});
watch(
() => props.deviceId,
(newVal) => {
if (newVal) {
getLocateRecord();
}
}
);
const getLocateRecord = () => {
let d = new Date();
locateRecord({
deviceId: props.deviceId,
startDate: `${format(d, "YYYY-MM-DD")} 00:00:00`,
endDate: `${format(d, "YYYY-MM-DD")} 23:59:59`,
}).then((res) => {
if (res && res.length) {
let list = res;
newMap.clearMap();
newMap.setCenter([list[0].lng, list[0].lat]);
newMap.polyline(list);
let icon = newMap.newIcon(location);
list.forEach((item) => {
let marker = newMap.marker({ icon, position: [item.lng, item.lat] });
marker.setMap(newMap.map);
marker.on("click", () => {
locationInfo.value = item;
InfoWin = newMap.infoWindow();
InfoWin.open(newMap.map, marker.getPosition());
});
});
}
});
};
onMounted(() => {
newMap = new MapCustom({ dom: "mapcontainer" });
getLocateRecord();
});
</script>
<style scoped lang="less">
.monitoringMap {
width: 100%;
height: 400px;
flex-shrink: 0;
}
</style>