百度地图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();官网文档解释如下
我这里不需要对marker进行移除操作,所以设置如下:
marker.disableMassClear();
第二步:清除所要清除的覆盖物,这里需要清除所有的Polyline而不清除marker,现在可以直接使用
map.clearOverlays();
这样就能很方便的清除所有Polyline而保留marker;
第三步:当后来需要对marker进行移除操作时,可以使用enableMassClear()方法来取消禁止清除;
但是需要对每个marker进行恢复操作,所以需要进行遍历:
var allOverlay = map.getOverlays();
for (var i = 0; i < allOverlay.length; i++) {
allOverlay[i].enableMassClear();
}
这样就恢复了所有覆盖物的可清除操作。
简单三步设置便可高效操作指定类覆盖物。
清除覆盖物有两个方法: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.disableMassClear();
第二步:清除所要清除的覆盖物,这里需要清除所有的Polyline而不清除marker,现在可以直接使用
map.clearOverlays();
这样就能很方便的清除所有Polyline而保留marker;
第三步:当后来需要对marker进行移除操作时,可以使用enableMassClear()方法来取消禁止清除;
enableMassClear() | non e | 允许覆盖物在 map.clearOverlays 方法中被清除。 (自 1.1 新增) |
var allOverlay = map.getOverlays();
for (var i = 0; i < allOverlay.length; i++) {
allOverlay[i].enableMassClear();
}
这样就恢复了所有覆盖物的可清除操作。
简单三步设置便可高效操作指定类覆盖物。
相关文章推荐
- 基于百度地图api清除指定覆盖物(Overlay)的方法
- JS实现清除指定cookies的方法
- python清除指定目录内所有文件中script的方法
- 百度地图API-给自定义覆盖物添加事件方法
- ASP正则表达式清除HTML指定标签的方法
- python清除指定目录内所有文件中script的方法
- JS实现清除指定cookies的方法
- 百度地图api 热力图上 清空指定区的覆盖物(轮廓)的另一思路
- .net中清除EXCEL进程最有效的方法
- 解决"Visual Studio .NET 已检测到指定的 Web 服务器运行的不是 ASP.NET 1.1 版。您将无法运行 ASP.NET Web应用程序或服务"的方法
- 在DataGrid(WinForm)中改变符合指定条件的行颜色的方法
- 一个页面多个button时,按Enter触发指定button事件的方法
- QQ尾巴病毒jpg.exe的清除方法
- 任意指定透明色的绘图方法
- 清除SQLServer日志的两种方法
- netddeclnt.exe病毒清除方法
- 检测到指定的WEB服务器运行的不是ASP.NET 1.1版,您无法运行ASP.NET应用程序或服务和创建ASP.NET程序时候发生错误 HTTP/1.0 500 Server Error的解决方法
- 程序的方法启动或停止指定的系统后台服务
- “Visual Studio.net已检测到指定的Web服务器运行的不是Asp.net1.1版。您将无法运行Asp.net Web应用程序或服务”问题的解决方法
- 清除SQLSERVER数据库日志的方法