OpenLayers.滤器函数未按预期工作.事实上,根本不起作用



我正在尝试使用函数过滤器设置一个规则。但它不起作用:那一层上的线条只是黑色的。更重要的是,我提供的用于过滤功能的函数从未被调用。

有人能指出我犯了什么错误吗?

这是代码。

感谢您抽出时间和关心。

var my_filter = new OpenLayers.Filter.Function(
    function(attributes) {
       console.log(attributes);
       var x=0; 
       return true; 
});
var ruleLow = new OpenLayers.Rule({
    filter:my_filter ,
  symbolizer: {pointRadius: 10, fillColor: "green",
               fillOpacity: 0.5, strokeColor: "green"}
});

var my_style=new OpenLayers.Style( null,ruleLow);
var my_style_map=new OpenLayers.StyleMap({
    "temporary":my_style,
    "default":my_style,
    "select":my_style
});
this.vectors= new OpenLayers.Layer.Vector(
    "Vector Layer",
    {
        styleMap:my_style_map,
        renderers:this.renderer,
    }
);

我很高兴与您分享如何使用OpenLayers。滤器作用(所以我解决了我遇到的问题):那是我必须改变的。

无论如何,谢谢。

var my_filter = new OpenLayers.Filter.FeatureId({
    **type: OpenLayers.Filter.Function,**
    evaluate:function(attributes) {
       console.log(attributes);
       var x=0; 
       return true;
    }
});
var ruleLow = new OpenLayers.Rule({
    filter:my_filter,
  });

var my_style=new OpenLayers.Style( {pointRadius: 7, fillColor: "#FF3300",
               fillOpacity: 0.5, strokeColor: "#FF3300"},**{rules:[ruleLow]}**);
var my_style_map=new OpenLayers.StyleMap({
    "temporary":my_style,
    "default":my_style,
    "select":my_style
});
this.vectors= new OpenLayers.Layer.Vector(
    "Vector Layer",
    {
        styleMap: my_style_map, 
        renderers:this.renderer,
    }
);

最新更新