如何在OpenLayers 4上添加点击事件?

时间:2017-03-24 16:25:32

标签: gis openlayers

我需要将一个事件监听器附加到OpenLayers 4中的一个功能。 我已经尝试了 feature.on('click',function(){...})但它无效。 如何将tan事件添加到功能? 提前谢谢。

2 个答案:

答案 0 :(得分:7)

没有为功能click对象注册ol.Feature个事件。但click存在ol.Map事件。使用forEachFeatureAtPixel方法获取像素的所有要素,并将其与要添加侦听器的要素进行比较。

相关代码:

var featureListener = function ( event ) {
    console.log("featureListenerCalled");
    alert("Feature Listener Called");
};

map.on('click', function(event) {

    map.forEachFeatureAtPixel(event.pixel, function(feature,layer) {
        if ( feature.getId() == "IND" ) {
                feature.setStyle(listenerStyle);
                featureListener(event);
        }
    });
});

我创建了这个演示link的插件。点击印度地图。

答案 1 :(得分:0)

var iconFeature = new ol.Feature({
  geometry: new ol.geom.Point(ol.proj.fromLonLat([lon, lat])),
  adres: adres
  //population: 4000,
  //rainfall: 500
});

// iconFeatureA is an array that gets all features on mouse click pixel location

map.on('click', function(e) {
  var iconFeatureA = map.getFeaturesAtPixel(e.pixel);
  if (iconFeatureA !== null) {
    var adres = iconFeatureA[0].get("adres");
    alert(adres);
    e.preventDefault(); // avoid bubbling 
  }
});