溫馨提示×

溫馨提示×

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

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

Openlayers實現(xiàn)圖形繪制

發(fā)布時間:2020-10-02 00:36:22 來源:腳本之家 閱讀:370 作者:桃李不言_下自成蹊 欄目:開發(fā)技術(shù)

本文實例為大家分享了Openlayers實現(xiàn)圖形繪制的具體代碼,供大家參考,具體內(nèi)容如下

1、新建一個html頁面,引入ol.js文件,然后在body中創(chuàng)建一個div標(biāo)簽、label標(biāo)簽和一個select下拉選項卡;

2、代碼實現(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/ol/ol.js"></script>
 <script type="text/javascript">
 window.onload = function () {
  //獲取下拉列表框
  var typeSelect = document.getElementById('type');
  //定義一個用來接收繪制對象的對象,方便以后對繪制對象進(jìn)行添加、移除等操作
  var draw;
 
  //初始化地圖對象
  var map = new ol.Map({
  target: 'map',
  layers: [
   new ol.layer.Tile({
   source: new ol.source.OSM()
   })
  ],
  view: new ol.View({
   center: [0, 0],
   zoom: 3
  })
  });
 
  //初始化矢量數(shù)據(jù)源對象
  //wrapX:Wrap the world horizontally. Default is true. 
  //For vector editing across the -180° and 180° meridians to work properly, this should be set to false
  var source = new ol.source.Vector({ wrapX: false });
  //實例化矢量數(shù)據(jù)圖層
  var vector = new ol.layer.Vector({
  //數(shù)據(jù)源
  source: source,
  //樣式
  style: new ol.style.Style({
   //樣式填充
   fill: new ol.style.Fill({
   //填充顏色
   color: 'rgba(37,241,239,0.2)'
   }),
   //筆觸
   stroke: new ol.style.Stroke({
   //筆觸顏色
   color: '#264df6',
   //筆觸寬度
   width:2
   }),
   //圖形樣式,主要適用于點(diǎn)樣式
   image: new ol.style.Circle({
   //半徑大小
   radius: 7,
   //填充
   fill: new ol.style.Fill({
    //填充顏色
    color: '#e81818'
   })
   })
  })
  });
 
  //將矢量圖層加載到map中
  map.addLayer(vector);
 
  //添加繪圖交互的函數(shù)
  function addInteraction() {
  //獲取當(dāng)前選擇的繪圖類型
  var value = typeSelect.value;
  //如果當(dāng)前選擇的繪圖類型不為"None"的話,則進(jìn)行相應(yīng)繪圖操作
  //如果當(dāng)前選擇的繪圖類型為"None"的話,則清空矢量數(shù)據(jù)源
  if (value !== 'None') {
   //如果當(dāng)前的矢量數(shù)據(jù)源為空的話,則重新創(chuàng)建和設(shè)置數(shù)據(jù)源
   //因為當(dāng)你選擇的繪圖類型為"None"時,會清空數(shù)據(jù)源
   if (source == null) {
   source = new ol.source.Vector({ wrapX: false });
   vector.setSource(source);
   }
   //geometryFunction變量,用來存儲繪制圖形時的回調(diào)函數(shù)
   //maxPoints變量,用來存儲最大的點(diǎn)數(shù)量
   var geometryFunction, maxPoints;
   //如果當(dāng)前選擇的繪圖類型是"Square"的話,則將value設(shè)置為Circle
   //然后調(diào)用createRegularPolygon()方法
   if (value === 'Square') {
   value = 'Circle';
   //Create a geometryFunction for type: 'Circle' 
   //that will create a regular polygon with a user specified number of sides and start angle instead of an ol.geom.
   //根據(jù)圓來創(chuàng)建一個四邊形
   geometryFunction = ol.interaction.Draw.createRegularPolygon(4);
   } else if (value === 'Rectangle') {
   //如果當(dāng)前選擇的繪圖類型是"Square"的話,則將value設(shè)置為LineString
   value = 'LineString';
   //設(shè)置最大點(diǎn)數(shù)為2
   maxPoints = 2;
   geometryFunction = function (coordinates, geometry) {
    //如果geometry對象不存在或者為空,則創(chuàng)建
    if (!geometry) {
    geometry = new ol.geom.Polygon(null);
    }
    //開始點(diǎn)的坐標(biāo)
    var start = coordinates[0];
    //結(jié)束點(diǎn)的坐標(biāo)
    var end = coordinates[1];
    //根據(jù)開始坐標(biāo)和結(jié)束坐標(biāo)設(shè)置繪圖點(diǎn)坐標(biāo)
    geometry.setCoordinates([
    [start, [start[0], end[1]], end, [end[0], start[1]], start]
    ]);
    return geometry;
   };
   }
 
   //將交互繪圖對象賦給draw對象
   //初始化交互繪圖對象
   draw = new ol.interaction.Draw({
   //數(shù)據(jù)源
   source: source,
   //繪制類型
   type: value,
   //回調(diào)函數(shù)
   //Function that is called when a geometry's coordinates are updated
   geometryFunction: geometryFunction,
   //最大點(diǎn)數(shù)
   maxPoints: maxPoints
   });
   //將draw對象添加到map中,然后就可以進(jìn)行圖形繪制了
   map.addInteraction(draw);
  } else {
   //清空矢量數(shù)據(jù)源
   source = null;
   //設(shè)置矢量圖層的數(shù)據(jù)源為空
   vector.setSource(source);
  }
  }
 
  //當(dāng)繪制類型下拉列表框的選項發(fā)生改變時執(zhí)行
  typeSelect.onchange = function (e) {
  //從map中移除交互繪圖對象
  //如果不移除,則會在下拉列表框選項發(fā)生改變時再次進(jìn)行繪制時,保留上一次的draw對象
  map.removeInteraction(draw);
  //執(zhí)行添加繪圖交互的函數(shù)
  addInteraction();
  };
  //添加繪圖交互的函數(shù)
  //此處是為保證刷新頁面后,仍然能夠根據(jù)下拉列表框框的選項進(jìn)行圖形繪制
  addInteraction();
 };
 </script>
</head>
<body>
 <div id="menu">
 <label>幾何圖形繪制:</label>
 <select id="type">
  <option value="None">無</option>
  <option value="Point">點(diǎn)</option>
  <option value="LineString">線</option>
  <option value="Polygon">多邊形</option>
  <option value="Circle">圓</option>
  <option value="Square">正方形</option>
  <option value="Rectangle">長方形</option>
 </select>
 </div>
 <div id="map"></div>
</body>
</html>

3、結(jié)果展示

繪制點(diǎn)圖形

Openlayers實現(xiàn)圖形繪制

繪制線圖形

Openlayers實現(xiàn)圖形繪制

繪制多邊形

Openlayers實現(xiàn)圖形繪制

繪制圓形

Openlayers實現(xiàn)圖形繪制

繪制正方形

Openlayers實現(xiàn)圖形繪制

繪制矩形

Openlayers實現(xiàn)圖形繪制

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

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

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

AI