您的位置:首页 > 其它

百度地图api清除指定覆盖物(Overlay)的方法

2017-06-26 19:39 176 查看
最近用百度地图api做项目,需要同时在地图显示marker与Polyline,且Polyline需要根据点击来显示或清除,所以遇到了清除指定覆盖物的问题,各种搜索后未能找到完美的解决方法,通过自己思考,摸索了一方法能解决这个问题,发出来给大家分享。好了,进入正题:

清除覆盖物有两个方法:map.removeOverlay()或者
map.clearOverlays(),clearOverlays()方法一次移除所有的覆盖物,removeOverlay()一次移除一个指定覆盖物,显然,我要一次移除一类Polyline覆盖物,这两个方法都不适用。

百度demo(http://developer.baidu.com/map/jsdemo.htm#c1_17)有removeOverlay()的例子,如下:

function deletePoint(){

        var allOverlay = map.getOverlays();

        for (var i = 0; i < allOverlay.length -1; i++){

            if(allOverlay[i].getLabel().content == "我是id=1"){

                map.removeOverlay(allOverlay[i]);

                return false;

            }

        }

    }

是通过遍历所有覆盖物来筛选所要移除的覆盖;

对于要移除一类覆盖物;可以在添加覆盖物的时候做限制设置;

第一步:在添加覆盖的时候对不需要进行移除操作的覆盖设置disableMassClear();官网文档解释如下

disableMassClear() non

e
禁止覆盖物在 map.clearOverlays
方法中被清除。 (自
1.1
新增)
我这里不需要对marker进行移除操作,所以设置如下:

marker.disableMassClear();

第二步:清除所要清除的覆盖物,这里需要清除所有的Polyline而不清除marker,现在可以直接使用

map.clearOverlays();

这样就能很方便的清除所有Polyline而保留marker;

第三步:当后来需要对marker进行移除操作时,可以使用enableMassClear()方法来取消禁止清除;

enableMassClear() non

e
允许覆盖物在 map.clearOverlays
方法中被清除。 (自
1.1
新增)
但是需要对每个marker进行恢复操作,所以需要进行遍历:

var allOverlay = map.getOverlays();

            for (var i = 0; i < allOverlay.length; i++) {

                allOverlay[i].enableMassClear();

            }
这样就恢复了所有覆盖物的可清除操作。

简单三步设置便可高效操作指定类覆盖物。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  百度地图 api overlay