0

我正在尝试创建一个突出显示层以在地图上选择时显示某些点 - newMarker 信号来自服务器,带来一个objectID,然后我想将相应的点(由当前变量表示)添加到过滤层。但是,过滤器没有拾取任何添加到它的点:

 socket.on('newMarker', function(data) {
     var current = map.queryRenderedFeatures({layers:['tax']}) 
                  [parseInt(data['newMarker'])];
     SPoints.unshift(current.properties.ID);

     var filter = ['match', ['get', 'ID'],'SPoints', true, false];
     map.setFilter('place-highlight', filter);

     var newLayer = map.queryRenderedFeatures({layers:['place- 
                    highlight']});
});

我试图将点添加到的图层:

 map.addLayer({ 
      'id': 'place-highlight',
      'type': 'circle', 
      'source': 'tax',
      'source-layer': 'AllPointsGeoJSON-12eyog',
      'paint': {
        'circle-color': '#00ff00',
        'circle-radius': 20,
        'circle-opacity': 1,
      },
      'filter': ['==', 'ID', -1]
    });

我很确定问题出在我格式化过滤器的方式上——如果我颠倒真假的顺序,我会看到每一点的所有样式。非常感谢您的帮助!

4

1 回答 1

2

出了问题的是这SPoints是一个局部变量(大概是一个数组),但是您传递的是一个字符串,"SPoints".

你应该这样做:

var filter = ['match', ['get', 'ID'], SPoints, true, false];
于 2018-07-11T02:52:22.940 回答