如何刷新融合层和过滤显示的标记

How to refresh fusion layer and filter displayed markers

我想使用 Google 地图中的 Fusion 层将路由器的位置和状态显示为标记,其中标记的颜色告诉您它的状态。因此,Fusion table 中的数据经常更改,这意味着地图必须自行刷新才能显示 table

中的更改

我在 javascript 中使用以下代码设法刷新图层:

function refresh()
{
  layer.setOptions({
            query: {
                select: '\'location\'',
                from: dbloc,
                where: "location != " + (-1 * Math.floor(Math.random() * 10000000)).toString()
            },
            styleId: styleNr,
            map: map
   }); 

}

此函数每十秒调用一次,在地图上显示所有标记时完美运行,但当我想根据另一列(在本例中为状态列)过滤标记时,没有任何反应。

我尝试像这样为状态添加过滤器:

where: "location != " + (-1 * Math.floor(Math.random() * 10000000)).toString() + " and " + "status = " + selectedStatus

我也试过将它们放在一个数组中并将其传递给查询:

var refreshClause = "location != " + (-1 * Math.floor(Math.random() * 10000000)).toString();
var statusClause = "status = " + selectedStatus;

where: [refreshClause, statusClause]

遗憾的是,这两个都不起作用。

如果我使用条件按状态过滤而不使用刷新融合层所需的条件,则标记会按给定状态正确过滤。唯一的问题是,如果 Fusion table 中的数据发生变化,显示的标记将不再发生变化。因此,如果我显示状态为 1 的标记并将其中一个标记更改为状态 2,则该标记会保留在地图上而不是消失。

是我做错了什么还是有其他方法?重要的是我可以过滤显示的标记,因为会有很多标记并且地图必须自行刷新才能显示路由器的当前状态。

有什么想法吗?

我通过使用 REST-API 测试我的查询设法解决了这个问题。原来是“!=”部分导致了问题,在用 "NOT IN()" 替换“!=”之后,我能够过滤标记并按照我的意愿不断刷新它们。

新查询如下所示:

where: "Location NOT IN('" + (-1 * Math.floor(Math.random() * 10000000)).toString() +  "')" + " AND Status = '" + selectedStatus + "'"

感谢大家的帮助。