欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Openlayers繪制地圖標(biāo)注

 更新時間:2020年09月28日 14:15:47   作者:桃李不言_下自成蹊  
這篇文章主要為大家詳細(xì)介紹了Openlayers繪制地圖標(biāo)注,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了Openlayers繪制地圖標(biāo)注的具體代碼,供大家參考,具體內(nèi)容如下

1、標(biāo)注的簡介

標(biāo)注簡單點(diǎn)說就是通過圖標(biāo)、文字等方式將我們想展示的內(nèi)容顯示在地圖上,著重突出人們所關(guān)注的專題內(nèi)容,從而為用戶提供個性化的地圖服務(wù);

2、標(biāo)注方式

在Openlayers3里面,有兩種對地理位置點(diǎn)進(jìn)行標(biāo)注的方法,一種是通過創(chuàng)建矢量圖層然后設(shè)置其樣式的方法,還有一種就是創(chuàng)建Overlay覆蓋層的方法;對于第一種方式,本質(zhì)上創(chuàng)建的還是一個矢量對象,只是將其表現(xiàn)形式更換了一下,用Style樣式進(jìn)行包裝;而第二種方式則是創(chuàng)建的一個單獨(dú)的覆蓋層,然后通過設(shè)置其屬性進(jìn)行某些信息的展示;至于具體使用哪一種方式,還是得根據(jù)具體來看;

3、代碼實(shí)現(xiàn)

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
 <title></title>
 <script src="../lib/jquery/jquery.js"></script>
 <script src="../lib/ol/ol.js"></script>
 <link href="../css/ol.css" rel="stylesheet" />
 <style type="text/css">
  body, html, div, ul, li,img
  {
   border:none;
   padding:0px;
   margin:0px;
  }
  #menu
  {
   width:100%;
   height:20px;
   padding:5px 10px;
   left:10px;
   font-size:14px;
   font-family:"微軟雅黑";
  }
  .checkbox
  {
   margin:5px 15px;
  }
  .marker
  {
   width:20px;
   height:20px;
   border:1px solid #088;
   border-radius:10px;
   background-color:#0FF;
   opacity:0.5;
  }
  .address
  {
   text-decoration:none;
   color:#aa3300;
   font-size:14px;
   font-weight:bold;
   text-shadow:black 0.1em 0.1em 0.2em;
  }
 </style>
 <script type="text/javascript">
  $(function () {
   //北京地理坐標(biāo)
   var beijing = ol.proj.fromLonLat([116.28, 39.54]);
   //武漢地理坐標(biāo)
   var wuhan = ol.proj.fromLonLat([114.21,30.37]);
 
   //初始化地圖
   var map = new ol.Map({
    target: 'map',
    layers: [
     new ol.layer.Tile({
      source:new ol.source.OSM()
     })
    ],
    view: new ol.View({
     center: beijing,
     zoom: 6,
     minZoom:2
    })
   });
 
   //創(chuàng)建標(biāo)簽的樣式
   var createLabelStyle = function (feature) {
    //返回一個樣式
    return new ol.style.Style({
     //把點(diǎn)的樣式換成ICON圖標(biāo)
     image: new ol.style.Icon({
      //控制標(biāo)注圖片和文字之間的距離
      anchor: [0.5, 60],
      //標(biāo)注樣式的起點(diǎn)位置
      anchorOrigin: 'top-right',
      //X方向單位:分?jǐn)?shù)
      anchorXUnits: 'fraction',
      //Y方向單位:像素
      anchorYUnits: 'pixels',
      //偏移起點(diǎn)位置的方向
      offsetOrigin: 'top-right',
      //透明度
      opacity: 0.75,
      //圖片路徑
      src: '../images/label/blueIcon.png'
     }),
     //文本樣式
     text: new ol.style.Text({
      //對齊方式
      textAlign: 'center',
      //文本基線
      textBaseline: 'middle',
      //字體樣式
      font: 'normal 14px 微軟雅黑',
      //文本內(nèi)容
      text: feature.get('name'),
      //填充樣式
      fill: new ol.style.Fill({
       color: '#aa3300'
      }),
      //筆觸
      stroke: new ol.style.Stroke({
       color: '#ffcc33',
       width: 2
      })
     })
    });
   };
 
   //初始化要素
   var iconFeature = new ol.Feature({
    //點(diǎn)要素
    geometry: new ol.geom.Point(beijing),
    //名稱屬性
    name: '北京市',
    //人口屬性
    population: 2115
   });
   //為點(diǎn)要素添加樣式
   iconFeature.setStyle(createLabelStyle(iconFeature));
 
   //初始化矢量數(shù)據(jù)源
   var vectorSource = new ol.source.Vector({
    //指定要素
    features:[iconFeature]
   });
 
   //初始化矢量圖層
   var vectorLayer = new ol.layer.Vector({
    //數(shù)據(jù)源
    source:vectorSource
   });
   //將矢量圖層添加到map中
   map.addLayer(vectorLayer);
 
   //初始化覆蓋層標(biāo)注
   var marker = new ol.Overlay({
    //位置坐標(biāo)
    position: wuhan,
    //覆蓋層如何與位置坐標(biāo)匹配
    positioning: 'center-center',
    //覆蓋層的元素
    element: document.getElementById('marker'),//ToDo 此處不能用JQuery方式$('#marker')獲取元素
    //事件傳播到地圖視點(diǎn)的時候是否應(yīng)該停止
    stopEvent:false
   });
   //將覆蓋層添加到map中
   map.addOverlay(marker);
 
   //設(shè)置覆蓋層的title屬性
   marker.getElement().title = '武漢市';
   //初始化文本覆蓋層
   var text = new ol.Overlay({
    //位置
    position: wuhan,
    //覆蓋層的元素
    element: document.getElementById('address')
   });
   //將文本覆蓋層添加到map中
   map.addOverlay(text);
   //設(shè)置文本覆蓋層的內(nèi)容為之前創(chuàng)建的覆蓋層的title屬性
   text.getElement().innerText = marker.getElement().title;
 
   //地圖的點(diǎn)擊事件
   map.on('click', function (evt) {
    //獲取單選按鈕的選項(xiàng)
    var type = $('input[name="label"]:checked').val();
    //獲取位置坐標(biāo)
    var point = evt.coordinate;
    //如果類型是矢量標(biāo)注則添加矢量標(biāo)簽,否則添加覆蓋標(biāo)簽
    if (type == 'vector') {
     addVectorLabel(point);
    } else if (type == 'overlay') {
     addOverlayLabel(point);
    } 
   });
 
   //添加矢量標(biāo)簽
   function addVectorLabel(coordinate) {
    //初始化一個新的點(diǎn)要素
    var newFeature = new ol.Feature({
     geometry: new ol.geom.Point(coordinate),
     name: '標(biāo)注點(diǎn)'
    });
    //設(shè)置點(diǎn)的樣式
    newFeature.setStyle(createLabelStyle(newFeature));
    //將當(dāng)前要素添加到矢量數(shù)據(jù)源中
    vectorSource.addFeature(newFeature);
   }
 
   //添加覆蓋標(biāo)注
   function addOverlayLabel(coordinate) {
    //創(chuàng)建一個div元素
    var elementDiv = document.createElement('div');
    //設(shè)置div元素的樣式類
    elementDiv.className = 'marker';
    //設(shè)置div元素的title屬性
    elementDiv.title = '標(biāo)注點(diǎn)';
 
    //獲取id為label的div標(biāo)簽
    var overlay = document.getElementById('label');
    //將新創(chuàng)建的div標(biāo)簽添加到overlay中
    overlay.appendChild(elementDiv);
 
    //創(chuàng)建一個a標(biāo)簽元素
    var elementA = document.createElement('a');
    //設(shè)置a標(biāo)簽的樣式類
    elementA.className = 'address';
    //設(shè)置a標(biāo)簽的鏈接地址
    elementA.href = '#';
    //設(shè)置a標(biāo)簽的超鏈接文本
    setInnerText(elementA, elementDiv.title);
    //將a標(biāo)簽元素添加到div標(biāo)簽元素中
    elementDiv.appendChild(elementA);
 
    //新建一個覆蓋層
    var newMarker = new ol.Overlay({
     //設(shè)置位置為當(dāng)前鼠標(biāo)點(diǎn)擊的坐標(biāo)
     position: coordinate,
     //設(shè)置覆蓋層與位置之間的匹配方式
     positioning: 'center-center',
     //覆蓋層元素
     element: elementDiv,
     //事件傳播到地圖視點(diǎn)的時候是否應(yīng)該停止
     stopEvent:false
    });
    //將覆蓋層添加到map中
    map.addOverlay(newMarker);
 
    //新建一個文本覆蓋層
    var newText = new ol.Overlay({
     //設(shè)置位置為當(dāng)前鼠標(biāo)點(diǎn)擊的坐標(biāo)
     position: coordinate,
     //覆蓋層元素
     element:elementA
    });
    //將文本覆蓋層添加到map中
    map.addOverlay(newText);
   }
 
   //設(shè)置文本內(nèi)容
   function setInnerText(element,text) {
    if (typeof element.textContent == 'string') {
     element.textContent = text;
    } else {
     element.innerText = text;
    }
   }
  });
 </script>
</head>
<body>
 <div id="menu">
  <label class="checkbox">
   <input type="radio" name="label" value="vector" checked="checked" />
   Vector Label
  </label>
  <label class="checkbox">
   <input type="radio" name="label" value="overlay" />
   Overlay Label
  </label>
 </div>
 <div id="map"></div>
 <div id="label" style="display:none">
  <div id="marker" class="marker" title="Marker">
   <a class="address" id="address" target="_blank" >標(biāo)注點(diǎn)</a>
  </div>
 </div>
</body>
</html>

4、結(jié)果展示

初始化頁面

選中第一個單選按鈕,在地圖頁面上的任何地方點(diǎn)擊,將會添加矢量標(biāo)注

選中第二個單選按鈕,則在頁面任意地方單擊,將添加覆蓋標(biāo)注

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

相關(guān)文章

  • 詳解JS中???和?.?和||的區(qū)別

    詳解JS中???和?.?和||的區(qū)別

    這篇文章主要介紹了詳解JS中???和?.?和||的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • JS實(shí)現(xiàn)拖拽的方法分析

    JS實(shí)現(xiàn)拖拽的方法分析

    這篇文章主要介紹了JS實(shí)現(xiàn)拖拽的方法,結(jié)合實(shí)例形式分析了JS拖拽的實(shí)現(xiàn)原理、實(shí)現(xiàn)技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2016-12-12
  • JAVA四種基本排序方法實(shí)例總結(jié)

    JAVA四種基本排序方法實(shí)例總結(jié)

    這篇文章主要介紹了JAVA四種基本排序方法,較為詳細(xì)的總結(jié)分析了插入法、冒泡法、選擇法及Shell排序等四種常用的排序技巧,非常具有實(shí)用價值,需要的朋友可以參考下
    2015-07-07
  • Bootstrap簡單實(shí)用的表單驗(yàn)證插件BootstrapValidator用法實(shí)例詳解

    Bootstrap簡單實(shí)用的表單驗(yàn)證插件BootstrapValidator用法實(shí)例詳解

    這篇文章主要介紹了Bootstrap簡單實(shí)用的表單驗(yàn)證插件BootstrapValidator用法,結(jié)合實(shí)例形式詳細(xì)分析了Bootstrap表單驗(yàn)證插件BootstrapValidator基本功能、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-03-03
  • 用js判斷輸入是否為中文的函數(shù)

    用js判斷輸入是否為中文的函數(shù)

    本篇文章主要是對js判斷輸入是否為中文的函數(shù)進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-03-03
  • TypeScript工具類 Partial 和 Required 的場景分析

    TypeScript工具類 Partial 和 Required 的場景分析

    這篇文章主要介紹了TypeScript工具類 Partial 和 Required 的詳細(xì)講解,本文通過場景描述給大家詳細(xì)講解工具類的使用,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • js移動焦點(diǎn)到最后位置的簡單方法

    js移動焦點(diǎn)到最后位置的簡單方法

    下面小編就為大家?guī)硪黄猨s移動焦點(diǎn)到最后位置的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • 解決前后端交互數(shù)據(jù)出現(xiàn)精度丟失的多種方式

    解決前后端交互數(shù)據(jù)出現(xiàn)精度丟失的多種方式

    這篇文章主要為大家介紹了解決前后端交互數(shù)據(jù)出現(xiàn)精度丟失的多種方式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • JavaScript使用Range調(diào)色及透明度實(shí)例

    JavaScript使用Range調(diào)色及透明度實(shí)例

    本文給大家分享的是使用range做的一個簡單的手動調(diào)色并可以得到RGB值的小工具,非常的實(shí)用,有需要的小伙伴可以參考下
    2016-09-09
  • JavaScript體驗(yàn)異步更好的解決辦法

    JavaScript體驗(yàn)異步更好的解決辦法

    本篇文章主要給大家講述了JavaScript體驗(yàn)異步更好的解決辦法,有這方面需要的朋友跟著學(xué)習(xí)參考下吧。
    2018-01-01

最新評論