基于百度地圖api清除指定覆蓋物(Overlay)的方法
最近用百度地圖api做項目,需要同時在地圖顯示marker與Polyline,且Polyline需要根據(jù)點擊來顯示或清除,所以遇到了清除指定覆蓋物的問題,各種搜索后未能找到完美的解決方法,通過自己思考,摸索了一方法能解決這個問題,發(fā)出來給大家分享。好了,進(jìn)入正題:
清除覆蓋物有兩個方法: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; } } }
是通過遍歷所有覆蓋物來篩選所要移除的覆蓋;
對于要移除一類覆蓋物;可以在添加覆蓋物的時候做限制設(shè)置;
第一步:在添加覆蓋的時候?qū)Σ恍枰M(jìn)行移除操作的覆蓋設(shè)置disableMassClear();官網(wǎng)文檔解釋如下
disableMassClear()
none 禁止覆蓋物在 map.clearOverlays 方法中被清除。 (自 1.1新增)
我這里不需要對marker進(jìn)行移除操作,所以設(shè)置如下:
marker.disableMassClear();
第二步:清除所要清除的覆蓋物,這里需要清除所有的Polyline而不清除marker,現(xiàn)在可以直接使用
map.clearOverlays();
這樣就能很方便的清除所有Polyline而保留marker;
第三步:當(dāng)后來需要對marker進(jìn)行移除操作時,可以使用enableMassClear()方法來取消禁止清除;
enableMassClear()
none 允許覆蓋物在 map.clearOverlays 方法中被清除。 (自 1.1新增)
但是需要對每個marker進(jìn)行恢復(fù)操作,所以需要進(jìn)行遍歷:
var allOverlay = map.getOverlays(); for (var i = 0; i < allOverlay.length; i++) { allOverlay[i].enableMassClear(); }
這樣就恢復(fù)了所有覆蓋物的可清除操作。
簡單三步設(shè)置便可高效操作指定類覆蓋物。
以上這篇基于百度地圖api清除指定覆蓋物(Overlay)的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
學(xué)習(xí)JavaScript事件流和事件處理程序
這篇文章主要為大家介紹了學(xué)習(xí)JavaScript事件流和事件處理程序的注意事項,感興趣的小伙伴們可以參考一下2016-01-01jquery實現(xiàn)文本框textarea自適應(yīng)高度
這篇文章主要介紹了jquery實現(xiàn)文本框textarea自適應(yīng)高度的相關(guān)資料,需要的朋友可以參考下2016-03-03