gpt4 book ai didi

javascript - 要素绘制完成后如何触发功能?

转载 作者:数据小太阳 更新时间:2023-10-29 05:37:27 24 4
gpt4 key购买 nike

我在我的项目中使用 openlayers 2。

绘制完成后我在 map 上绘制了3种类型的特征我需要触发名为featureDrawed的函数。

她是我的代码:

drawControl = {
point: new OpenLayers.Control.DrawFeature(new OpenLayers.Layer.Vector("Point Layer"), OpenLayers.Handler.Point } }),
line: new OpenLayers.Control.DrawFeature(new OpenLayers.Layer.Vector("Line Layer"), OpenLayers.Handler.Path),
polygon: new OpenLayers.Control.DrawFeature(new OpenLayers.Layer.Vector("Polygon Layer"), OpenLayers.Handler.Polygon)
}

for (var key in drawControl) {
control = drawControl[key];
controls.push(control);
}

这是用户选择要绘制的要素的 html:

    <div data-role="popup" id="popupShapes" data-theme="none" style="z-index:999">
<div data-role="collapsibleset" data-theme="b" data-content-theme="a" style="margin:0; width:250px;">
<div data-role="listview" data-inset="false">
<ul data-role="listview">
<li>
<input type="radio" name="type" value="point" id="pointToggle" />
<label for="pointToggle">draw point</label>
</li>
<li>
<input type="radio" name="type" value="line" id="lineToggle" />
<label for="lineToggle">draw line</label>
</li>
<li>
<input type="radio" name="type" value="polygon" id="polygonToggle" />
<label for="polygonToggle">draw polygon</label>
</li>
</ul>
</div>
</div>
</div>

这是在用户选择要绘制的形状后触发的事件。

$("#popupShapes ul li input").click(function () {
var val = $(this).val();

for (key in drawControl) {
var control = drawControl[key];
if (val == key) {
control.activate();
} else {
control.deactivate();
}
}
});

代码运行良好。但问题是我无法创建在 map 上绘制要素后触发的事件。

最佳答案

声明绘制结束时调用的函数:

var onDrawEnd = function(e) {
console.log('feature added', e.feature);
//your logic
};

为每个控件注册一个监听器:

for (var key in drawControl) {
control = drawControl[key];
control.events.register('featureadded', null, onDrawEnd);
controls.push(control);
}

关于javascript - 要素绘制完成后如何触发功能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48768272/

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