如何在 180° 子午线附近显示 Leaflet 标记?
IT技术
javascript
leaflet
2021-03-13 08:41:49
4个回答
只需确保标记的经度在 range0..360
而不是 range 中-180..180
。请参阅一个工作示例。
即代替
L.marker([0,170]).addTo(map);
L.marker([0,-180]).addTo(map);
L.marker([0,-170]).addTo(map);
做类似的事情
L.marker([0,170]).addTo(map);
L.marker([0,180]).addTo(map);
L.marker([0,190]).addTo(map);
换句话说,如果经度小于零,则向其添加 360。L.Util.wrapNum(lng, [0,360], true)
如果您打算一次过滤所有经度,您可能想改用它。
曾经遇到过类似的问题,并在Leaflet Github上报告
解决方案是增加标记的经度,如果它们的初始经度低于 0。
var totalMarkers = markerPositions.length;
for(var i = 0; i<totalMarkers; i++){
var mData = markerPositions[i];
if (mData.lon < 0) {
mData.lon += 360;
}
L.marker([mData.lat, mData.lon]).addTo(map);
}
另一种方法是利用Leaflet.RepeatedMarkers 插件,它将显示每 360 度经度的每个标记的副本:
将此应用于反子午线附近的标记也有效,例如:
var myRepeatingMarkers = L.gridLayer.repeatedMarkers().addTo(map);
L.polyline([[-85,180],[85,180]]).addTo(map);
L.polyline([[-85,-180],[85,-180]]).addTo(map);
myRepeatingMarkers.addMarker(L.marker([0,140]));
myRepeatingMarkers.addMarker(L.marker([0,150]));
myRepeatingMarkers.addMarker(L.marker([0,160]));
myRepeatingMarkers.addMarker(L.marker([0,170]));
myRepeatingMarkers.addMarker(L.marker([0,180]));
myRepeatingMarkers.addMarker(L.marker([0,-170]));
myRepeatingMarkers.addMarker(L.marker([0,-160]));
myRepeatingMarkers.addMarker(L.marker([0,-150]));
myRepeatingMarkers.addMarker(L.marker([0,-140]));
将显示如下内容:
谢谢大家的帮助。实际上,我没有使用您建议的代码,但我想到了修复它。
这是我的解决方案,希望对其他寻求相同解决方案的人有所帮助: 已解决的截图
始终在地图上显示图标及其副本(在您想要的经度范围内,在我的情况下,它是从 0 到 360)
makeMarkers: (item) ->
markers = []
markers.push(item.makeMarker())
copy_marker = item.makeMarker()
copy_marker.setLatLng( new L.LatLng(copy_marker._latlng.lat, copy_marker._latlng.lng + 360) )
markers.push(copy_marker)
markers
在项目类中:
makeMarker: ->
LeafletIcon = L.Icon.extend(
options: {
iconSize: [25, 25],
iconAnchor: [10, 10],
popupAnchor: [0, 0]
},
)
icon = new LeafletIcon( {iconUrl: this.iconUrl} )
marker = L.marker([this.latitude, this.longitude], {icon: icon, zIndexOffset: 10})
marker.id = this.id
marker
再次感谢你。