【问题标题】:Leaflet and MarkerCluster - don't perform clustering when there is a popup currently open?Leaflet 和 MarkerCluster - 当前打开弹出窗口时不执行聚类?
【发布时间】:2019-12-20 09:00:05
【问题描述】:

我有一个 Leaflet + MarkerCluster 应用程序,该应用程序在地图上具有一些标记,并且在打开与标记关联的弹出窗口时(单击标记后)有一些逻辑可以将图像叠加层添加到地图中。我使用bindPopup() 将弹出窗口添加到标记。

markers.on('popupopen', function (e) {

    var b = e.layer.boundary;

    if (b) {

    //take some parameters for the overlay from an array that is passed as a
    //property of the marker

    var image = b[0];
    var LatStart = b[1];
    var LngStart = b[2];
    var LatEnd = b[3];
    var LngEnd = b[4];

//doOverlay() creates the overlay
var overlay = doOverlay(image,LatStart,LngStart,LatEnd,LngEnd);

//add the overlay to the map
map.addLayer(overlay);

//make the overlay widely-accessible as a window property
window.overlay = overlay;

}

doOverlay() 包含一些创建 ImageOverlay 的基本逻辑:

function doOverlay(image,LatStart,LngStart,LatEnd,LngEnd) {

  var bounds = new L.LatLngBounds (

  new L.LatLng(LatStart,LngStart),
  new L.LatLng(LatEnd,LngEnd));

var overlay = new L.ImageOverlay(image,
  bounds, {  
  pane: 'general'
});

    return overlay
}

但是,因为我使用 MarkerCluster 将标记分组到群集中,如果用户单击标记,获取弹出窗口并创建覆盖,然后他们缩小,就会发生群集,标记被群集,弹出窗口消失(但没有生成 popupclose 事件),我们最终会在地图上出现无法移除的重影叠加图像。

在正常情况下,当用户关闭弹出窗口(或单击地图上的其他位置或另一个标记)时,会生成“popupclose”事件并删除图像层:

markers.on('popupclose', removeOverlay);

function removeOverlay() {

  if (window.overlay) {

  map.removeLayer(overlay);
  window.overlay=null;

  }

目前,我不得不监听每个“animationend”事件(当地图上任何地方由 MarkerCluster 控制的集群发生任何变化时),然后删除图层并关闭弹出窗口,这是一种非常糟糕的方法,因为用户在准备好缩放设置后必须再次点击标记:

markers.on('animationend', function (e) {

    removeOverlay();

    map.closePopup();

});

【问题讨论】:

    标签: javascript leaflet leaflet.markercluster


    【解决方案1】:

    如果您希望您的标记及其弹出窗口保留在地图上并且不再由 MarkerClusterGroup 处理,那么一个简单的解决方案是在标记单击时将其从该组中删除(并将其直接添加到地图 + 打开弹出窗口)。

    然后当弹出窗口关闭时,将标记重新添加到您的 MarkerClusterGroup 中(首先将其从地图中删除;如果它应该是可见的,标记集群将添加回来)。

    至于缺少的“popupclose”事件,这确实是一个需要向 Leaflet.markercluster 或 Leaflet 报告的问题。

    【讨论】:

    • 你能给我一个关于如何做到这一点的小例子,因为简单地来自 MarkerCluster 组的removeLayer() 然后addLayer() 映射 + openPopup() 似乎不适用于我上面的代码?
    • 我找到了一个很好的例子来说明如何做到这一点:stackoverflow.com/a/51964768。感谢您为我指明正确的方向。
    猜你喜欢
    • 1970-01-01
    • 2018-03-17
    • 2016-05-29
    • 2014-10-07
    • 2022-12-01
    • 1970-01-01
    • 2023-04-11
    • 2012-09-20
    • 1970-01-01
    相关资源
    最近更新 更多