gpt4 book ai didi

javascript - 添加多个 Leaflet 层导致容器定位不准确

转载 作者:行者123 更新时间:2023-11-30 06:20:46 29 4
gpt4 key购买 nike

我有以下代码来扩展 Leaflet 层以添加自定义层。

L.CustomLayer = L.Layer.extend({
initialize: function (latlng, options) {
this._latlng = L.latLng(latlng);
L.Util.setOptions(this, options);
},
onAdd: function (map) {
this._div = document.createElement("div");
this._div.style.padding = "8px";
this._div.style.border = "2px solid grey";
this._div.style.borderRadius = "2px";
this.getPane().appendChild(this._div);
this._update();
map.on("zoomend viewreset", this._update, this);
},
onRemove: function (map) {
L.DomUtil.remove(this._div);
map.off("zoomend viewreset", this._update, this);
},
_update: function () {
var pos = this._map.latLngToLayerPoint(this._latlng);
L.DomUtil.setPosition(this._div, pos);
}
});

L.customLayer = function (latlng, options) {
return new L.CustomLayer(latlng, options);
};

但是,当我尝试分别在相同坐标处添加两个标记和两个自定义图层时,第二个图层似乎定位错误。

使用以下代码添加图层:

var customLayer1 = L.customLayer().setPosition([3.139003, 101.686852]).addTo(map);
var customLayer2 = L.customLayer().setPosition([6.121070, 100.369797]).addTo(map);

对此有何建议? CodePen 是 here .感谢您的帮助!

最佳答案

对于那些可能需要这条信息的人,我已经找到了问题所在。您需要通过以下操作将容器的位置设置为 absolute:

onAdd: function (map) {
this._div = document.createElement("div");
this._div.style.padding = "8px";
this._div.style.border = "2px solid grey";
this._div.style.borderRadius = "2px";

// Set "position" to "absolute" manually for "top" and "left"
// to work. Alternatively, apply CSS styles for leaflet-layer
// class by adding class for all the necessary styles
// this._div.style.position = "absolute";

// See the link below for all the styles included
// https://github.com/Leaflet/Leaflet/blob/master/dist/leaflet.css
L.DomUtil.addClass(this._div, "leaflet-layer");

this.getPane().appendChild(this._div);
this._update();
map.on("zoomend viewreset", this._update, this);
},

有关必要样式,请参阅 leaflet.css 的链接。 :D

关于javascript - 添加多个 Leaflet 层导致容器定位不准确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53256760/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com