基于百度地图api清除指定覆盖物(Overlay)的方法
最近用百度地图api做项目,需要在地图显示marker与Polyline,且Polyline需要根据点击来显示或清除,所以遇到了清除指定覆盖物的问题,各种搜索后未能找到完美的解决方法,通过自己思考,摸索了一方法能解决这个问题,发出来给大家分享。好了,进入正题
清除覆盖物有两个方法map.removeOverlay()或者 map.clearOverlays(),clearOverlays()方法一次移除所有的覆盖物,removeOverlay()一次移除一个指定覆盖物,显然,我要一次移除一类Polyline覆盖物,这两个方法都不适用。
百度demo(http://developer.baidu./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()
none 禁止覆盖物在 map.clearOverlays 方法中被清除。 (自 1.1新增)
我这里不需要对marker进行移除操作,所以设置如下
marker.disableMassClear();
第二步清除所要清除的覆盖物,这里需要清除所有的Polyline而不清除marker,现在可以直接使用
map.clearOverlays();
这样就能很方便的清除所有Polyline而保留marker;
第三步当后来需要对marker进行移除操作时,可以使用enableMassClear()方法来取消禁止清除;
enableMassClear()
none 允许覆盖物在 map.clearOverlays 方法中被清除。 (自 1.1新增)
需要对每个marker进行恢复操作,所以需要进行遍历
var allOverlay = map.getOverlays(); for (var i = 0; i < allOverlay.length; i++) { allOverlay[i].enableMassClear(); }
这样就恢复了所有覆盖物的可清除操作。
简单三步设置便可高效操作指定类覆盖物。
以上这篇基于百度地图api清除指定覆盖物(Overlay)的方法就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程