【问题标题】:How to fire function when feature drawing complete?特征绘制完成后如何触发功能?
【发布时间】:2018-02-13 13:44:57
【问题描述】:

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

绘制完成后我在地图上绘制了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();
        }
    }
});

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

【问题讨论】:

  • 不知道你在问什么,你能澄清一下吗?

标签: javascript gis openlayers


【解决方案1】:

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

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);
}

【讨论】:

    【解决方案2】:

    您可以使用 addEventListener 和 dispatchEvent。 例如:

    function DrawSomething(){
    /*drawing*/
    let event=new Event('featureDrawed');
    this.dispatchEvent(event);
    }
    

    代码中的某处

    DrawSomething.addEventListener('featureDrawed', function(){
    /*action you want to do when all you want is drawn*/
    })
    

    注意:画图前需要添加EventListener

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2013-05-20
      • 2020-07-15
      • 2021-03-05
      • 1970-01-01
      • 1970-01-01
      • 2017-04-07
      • 1970-01-01
      相关资源
      最近更新 更多