溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何實現(xiàn)基于百度地圖api清除指定覆蓋物Overlay的方法

發(fā)布時間:2021-08-13 09:09:51 來源:億速云 閱讀:746 作者:小新 欄目:web開發(fā)

這篇文章主要介紹如何實現(xiàn)基于百度地圖api清除指定覆蓋物Overlay的方法,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

清除覆蓋物有兩個方法: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行移除操作的覆蓋設(shè)置disableMassClear();官網(wǎng)文檔解釋如下

disableMassClear()

none 禁止覆蓋物在 map.clearOverlays 方法中被清除。 (自 1.1新增)

我這里不需要對marker進行移除操作,所以設(shè)置如下:

marker.disableMassClear();

第二步:清除所要清除的覆蓋物,這里需要清除所有的Polyline而不清除marker,現(xiàn)在可以直接使用

map.clearOverlays();

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

第三步:當(dāng)后來需要對marker進行移除操作時,可以使用enableMassClear()方法來取消禁止清除;

enableMassClear()

none 允許覆蓋物在 map.clearOverlays 方法中被清除。 (自 1.1新增)

但是需要對每個marker進行恢復(fù)操作,所以需要進行遍歷:

var allOverlay = map.getOverlays();
      for (var i = 0; i < allOverlay.length; i++) {
        allOverlay[i].enableMassClear();
      }

這樣就恢復(fù)了所有覆蓋物的可清除操作。

簡單三步設(shè)置便可高效操作指定類覆蓋物。

以上是“如何實現(xiàn)基于百度地圖api清除指定覆蓋物Overlay的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI