该插件依赖turfjs
插件
用来判断两个区块是否相同
https://turfjs.fenxianglu.cn/docs/api/booleanEqual
js
<template>
<Map ref="mapRef" />
</template>
<script setup lang='ts'>
import { onMounted, ref, toRaw } from 'vue'
import * as L from 'leaflet'
import * as turf from "@turf/turf"
onMounted(() => {
mapRef.value.map.on('moveend', () => {
drawMarker()
drawPolygon()
})
mapRef.value.map.fire('moveend')
})
const mapRef = ref()
// 绘制锚点
const addedMarkers: any[] = []
const drawMarker = () => {
// 模拟后台数据
const arr = [
{ id: 1, marker: [22.542800, 114.058000] },
{ id: 2, marker: [22.54, 114.05] }
]
const markerIcon = L.icon({ iconUrl: getAssetsFile('images/qf.png'), iconSize: [40, 40] })
const bounds = mapRef.value.map.getBounds()
for (let item of arr) {
const marker = L.marker(item.marker as unknown as L.LatLngExpression, { icon: markerIcon })
const latLng = L.latLng(item.marker[0], item.marker[1])
L.Util.extend(marker, { params: item })
// 判断在当前可见视图并且没有绘制过的
if (bounds.contains(marker.getLatLng()) && !addedMarkers.some(m => m.getLatLng().equals(latLng))) {
marker.addTo(toRaw(mapRef.value.map))
addedMarkers.push(marker)
}
}
}
// 绘制区块
const addedPolygons: any[] = []
const drawPolygon = () => {
const arr = [
{
id: 1,
polygon: [[22.548728, 114.061196], [22.546925, 114.059222], [22.540107, 114.064929], [22.546806, 114.068127], [22.548728, 114.061196]]
},
{
id: 2,
polygon: [[22.550096, 114.056904], [22.548986, 114.056818], [22.549937, 114.058599], [22.550096, 114.056904]]
}
]
const bounds = mapRef.value.map.getBounds()
for (let item of arr) {
const polygon = new L.Polygon(item.polygon as unknown as L.LatLngExpression[][], { color: greenColor })
L.Util.extend(polygon, { params: item }) //携带自定义参数
if (bounds.contains(polygon.getBounds()) && !addedPolygons.some(p => turf.booleanEqual(p.toGeoJSON(), polygon.toGeoJSON()))) {
// 使用 toRaw 处理popup关闭后伸缩地图报错:Cannot read properties of null (reading '_latLngToNewLayerPoint')
polygon.addTo(toRaw(mapRef.value.map))
addedPolygons.push(polygon)
}
}
}
</script>