这是我试图解决问题的日子。
我有一个GeoJSON的多边形图层。我想用click事件编辑我的多边形。当我点击一个多边形时,它变得可编辑,但我想要的是当我点击另一个多边形时,第一个多边形不再处于可编辑模式。
OpenLayers但自然不会传单。
这是我的代码的摘录:
var editableLayers = new L.FeatureGroup().addTo(map);
var polygon_json;
$.ajax({
type: "GET",
dataType: "json",
url: "get_json.php",
success: function (response) {
meaux_json = L.geoJson(response, {
onEachFeature: onEachFeature
});
}
});
//edit the targeted polygon
function onEachFeature (feature, layer) {
editableLayers.addLayer(layer);
layer.on('click', function(e){
e.target.editing.enable();
});
}
一个人能够做到但我很难理解: https://github.com/dwilhelm89/Ethermap
答案 0 :(得分:5)
我认为你很亲密。在onEachFeature函数中,您应该存储单击的功能,以便在单击处理程序中启用/禁用编辑。
var selectedFeature = null;
//edit the targeted polygon
function onEachFeature (feature, layer) {
editableLayers.addLayer(layer);
layer.on('click', function(e){
if(selectedFeature)
selectedFeature.editing.disable();
selectedFeature = e.target;
e.target.editing.enable();
});
}