亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

OpenLayers實(shí)現(xiàn)圖層切換控件

 更新時(shí)間:2020年09月25日 16:32:02   作者:不睡覺(jué)的怪叔叔  
這篇文章主要為大家詳細(xì)介紹了OpenLayers實(shí)現(xiàn)圖層切換控件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

OpenLayers并沒(méi)有封裝圖層切換的控件,所以我們需要自己來(lái)實(shí)現(xiàn)圖層控件。

自定義圖層切換控件的原理很簡(jiǎn)單:顯示某個(gè)圖層時(shí),將其他圖層隱藏。

完整代碼:

layerSwitch.html:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>圖層切換控件</title>
 <link rel="stylesheet" href="../v5.3.0/css/ol.css" />
 <script src="../v5.3.0/build/ol.js"></script>
</head>
<body>
 <div id="controls">
 <input type="checkbox" id="osm" checked />OpenStreetMap
 <input type="checkbox" id="bingmap" />Bing Map
 <input type="checkbox" id="stamen" />Stamen Map
 </div>
 <div id="map"></div>
 
 <script>
 let map = new ol.Map({
  target: 'map', // 關(guān)聯(lián)到對(duì)應(yīng)的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官網(wǎng)申請(qǐng)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){ // 如果選中某一復(fù)選框
  // 通過(guò)DOM元素的id值來(lái)判斷應(yīng)該對(duì)哪個(gè)圖層進(jìn)行顯示
  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{  // 如果取消某一復(fù)選框
  // 通過(guò)DOM元素的id值來(lái)判斷應(yīng)該對(duì)哪個(gè)圖層進(jìn)行隱藏
  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;
  }
  } 
 });
 </script>
</body>
</html>

實(shí)現(xiàn)效果:

代碼整體邏輯是很簡(jiǎn)單的,其中使用了事件委托這一機(jī)制來(lái)綁定事件,事件委托可以減少事件綁定導(dǎo)致的內(nèi)存消耗,所以平時(shí)開(kāi)發(fā)時(shí)推薦多使用事件委托。

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

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

怎么樣,自己實(shí)現(xiàn)一個(gè)圖層切換控件是不是很簡(jiǎn)單呢?

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論