在Leaflet地图上避免标记重叠的方法有很多种,以下是其中一种解决方案的代码示例:
// 创建地图实例
var map = L.map('map').setView([51.505, -0.09], 13);
// 添加地图瓦片图层
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
attribution: '© OpenStreetMap contributors'
}).addTo(map);
// 创建标记数组
var markers = [];
// 创建自定义图标
var customIcon = L.icon({
iconUrl: 'marker.png',
iconSize: [38, 95],
iconAnchor: [22, 94],
popupAnchor: [-3, -76]
});
// 添加标记
var marker1 = L.marker([51.5, -0.09], { icon: customIcon }).addTo(map);
markers.push(marker1);
var marker2 = L.marker([51.505, -0.085], { icon: customIcon }).addTo(map);
markers.push(marker2);
// 创建标记聚合组
var markerCluster = L.markerClusterGroup();
// 添加标记到聚合组
markerCluster.addLayers(markers);
// 添加聚合组到地图
map.addLayer(markerCluster);
在上面的示例中,我们首先创建了一个Leaflet地图实例,并添加了一个地图瓦片图层。然后,我们创建了一个标记数组,并定义了自定义的图标。接下来,我们创建了两个标记,并将它们添加到地图上,并将它们添加到标记数组中。最后,我们创建了一个标记聚合组,并将标记添加到聚合组中,并将聚合组添加到地图上。
通过使用标记聚合组,当标记重叠时,它们将被聚合成一个单独的标记,并在用户缩放地图时进行展开。这样可以避免在地图上出现标记重叠的问题。