Leaflet折线在平移时消失

3
我有一个带折线和许多图标的 Leaflet 地图。当我沿着折线平移地图时,图标总是可见的,但折线会消失。这种情况发生在拖动地图时(如果我缓慢平移),或者在地图移动时(如果我快速抓住地图并用快速的手势释放)。使用或不使用 { renderer: L.canvas() } 时,折线的行为都相同。为什么会出现这种情况,如何使折线在平移时可见?

var mymap = L.map('mapid').setView([51.505, -0.09], 10);

L.tileLayer('https://api.tiles.mapbox.com/v4/{id}/{z}/{x}/{y}.png?access_token=pk.eyJ1IjoibWFwYm94IiwiYSI6ImNpandmbXliNDBjZWd2M2x6bDk3c2ZtOTkifQ._QA7i5Mpkd_m30IGElHziw', {
  maxZoom: 18,
  attribution: 'Map data &copy; <a href="http://openstreetmap.org">OpenStreetMap</a> contributors, ' +
    '<a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, ' +
    'Imagery © <a href="http://mapbox.com">Mapbox</a>',
  id: 'mapbox.streets'
}).addTo(mymap);

var array = [];
for (var counter = 0; counter < 100; counter++) {
  array[counter] = [51.505 - counter * 0.1, -0.09 - counter * 0.1]
}

L.polyline(array, {
  renderer: L.canvas()
}).addTo(mymap);
for (var index = 0; index < array.length; index++) {
  var latlng = array[index];
  L.marker(latlng).addTo(mymap);
}
#mapid {
  height: 90vh;
}
<script src="https://unpkg.com/leaflet@1.0.3/dist/leaflet.js"></script>
<link href="https://unpkg.com/leaflet@1.0.3/dist/leaflet.css" rel="stylesheet" />

<div id="mapid"></div>

同样的演示,作为一个JSFiddle: https://jsfiddle.net/xbxrtx50/1/

1个回答

9

为什么会发生这种情况?

性能。

使用SVG或Canvas绘制图形是计算密集型的,并且会阻塞UI线程,因此Leaflet尽可能少地进行绘制。这意味着只有在没有缩放或平移交互时才进行重绘。

如何在平移时使线条可见?

手动实例化您的(或),并使用padding选项使其比地图的可见大小大得多。这将减轻渲染伪影。

您还可以尝试使用Leaflet.VectorGrid.Slicer,它应该以平铺的方式渲染几何图形,而地图正在被平移。


1
谢谢。我改变了padding选项,解决得很好。我将频繁更新折线几何图形;这对于Leaflet.VectorGrid.Slicer会有问题吗? - user2441511
1
是的,这可能是个问题。Leaflet.VectorGrid.Slicer 不适用于可能会改变的数据;切片操作是一项昂贵的操作。 - IvanSanchez

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接