微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MapBox:使用切换列表显示/隐藏标记

如何解决MapBox:使用切换列表显示/隐藏标记

我正在尝试了解如何基于动态切换列表显示/隐藏 MapBox 标记

目前,我有一个 MapBox 地图,我可以用这段代码成功地向它添加一堆 Markers;

for (var i = 0; i < markers.length; i++) {
    var la = markers[i]['lat'];
    var lo = markers[i]['long'];
    var siteName = markers[i]['Site Name']
    var siteType = markers[i]['Site Type']
    var siteAddr = markers[i]['Address']
    var colour = markers[i]["Colour"];

    new mapBoxgl.Marker({
    "color":colour
    })
    .setLngLat([lo,la])
    .setPopup(new mapBoxgl.Popup()
    .setHTML("<b>" + siteName + "</b><br>(" + siteType + ")<br>" + siteAddr )).addTo(map);
}

一切正常,我得到了一张漂亮的地图。

然后我从这个例子中获得灵感,并尝试根据 siteType 显示/隐藏标记,就像这里显示的那样; https://docs.mapbox.com/mapbox-gl-js/example/filter-markers/

我遇到的问题是该示例基于使用图层,而我的地图使用标记

我一直在尝试各种事情,但最终我什至不确定要采用什么策略,更不用说支持它所需的代码了。

是否可以使用切换列表显示/隐藏标记,还是我必须使用图层来实现这一点?如果可以,怎么做?以及如何使用图层自定义各个位置,以便它们可以有单独的弹出窗口?我不是在追求有人用勺子喂我代码(尽管我不会拒绝!),主要是我在寻求关于我可以采用的策略来实现我的目标的建议/讨论。

谢谢!

解决方法

标记和图层的行为完全不同。

使用图层,您可以将图层作为一个整体进行管理。您可以通过切换其可见性来隐藏/显示图层,或者通过修改过滤器来隐藏/显示单个元素。

使用标记,您可以单独管理每个标记。您可以使用 CSS 隐藏/显示标记(例如,将其 opacity 更改为 0),但更多情况下,您只需使用 Marker.remove() 删除标记并稍后再添加。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?