日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

    歡迎訪問 生活随笔!

    生活随笔

    當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

    编程问答

    openlayer 图层上下_OpenLayers实现图层切换控件

    發布時間:2023/12/19 编程问答 38 豆豆
    生活随笔 收集整理的這篇文章主要介紹了 openlayer 图层上下_OpenLayers实现图层切换控件 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

    OpenLayers并沒有封裝圖層切換的控件,所以我們需要自己來實現圖層控件。

    自定義圖層切換控件的原理很簡單:顯示某個圖層時,將其他圖層隱藏。

    完整代碼:

    layerSwitch.html:

    圖層切換控件

    OpenStreetMap

    Bing Map

    Stamen Map

    let map = new ol.Map({

    target: 'map', // 關聯到對應的div容器

    layers: [

    new ol.layer.Tile({ // OpenStreetMap圖層

    source: new ol.source.OSM()

    }),

    new ol.layer.Tile({ // Bing Map圖層

    source: new ol.source.BingMaps({

    key: '略', // 可以自行到Bing Map官網申請key

    imagerySet: 'Aerial'

    }),

    visible: false // 先隱藏該圖層

    }),

    new ol.layer.Tile({

    source: new ol.source.Stamen({

    layer: 'watercolor'

    }),

    visible: false // 先隱藏該圖層

    })

    ],

    view: new ol.View({ // 地圖視圖

    projection: 'EPSG:3857',

    center: [0, 0],

    zoom: 0

    })

    });

    let controls = document.getElementById('controls');

    // 事件委托

    controls.addEventListener('click', (event) => {

    if(event.target.checked){ // 如果選中某一復選框

    // 通過DOM元素的id值來判斷應該對哪個圖層進行顯示

    switch(event.target.id){

    case "osm":

    map.getLayers().item(0).setVisible(true);

    break;

    case "bingmap":

    map.getLayers().item(1).setVisible(true);

    break;

    case "stamen":

    map.getLayers().item(2).setVisible(true);

    break;

    default: break;

    }

    }else{ // 如果取消某一復選框

    // 通過DOM元素的id值來判斷應該對哪個圖層進行隱藏

    switch(event.target.id){

    case "osm":

    map.getLayers().item(0).setVisible(false);

    break;

    case "bingmap":

    map.getLayers().item(1).setVisible(false);

    case "stamen":

    map.getLayers().item(2).setVisible(false);

    default: break;

    }

    }

    });

    實現效果:

    代碼整體邏輯是很簡單的,其中使用了事件委托這一機制來綁定事件,事件委托可以減少事件綁定導致的內存消耗,所以平時開發時推薦多使用事件委托。

    另外,map.getLayers()返回一個ol.Collection類的對象,該對象中包含了地圖中的三個圖層對象(ol.layer.Tile),可以為item()方法傳入對應索引來取出對應圖層對象。

    最后,ol.layer.Tile類的setVisible()方法可以設置圖層的顯示與隱藏。

    怎么樣,自己實現一個圖層切換控件是不是很簡單呢?

    以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

    創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

    總結

    以上是生活随笔為你收集整理的openlayer 图层上下_OpenLayers实现图层切换控件的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。