美文网首页
利用 leaftlet+leaflet-draw 开发交互式地图

利用 leaftlet+leaflet-draw 开发交互式地图

作者: _花 | 来源:发表于2022-02-10 09:19 被阅读0次

leaftlet官方文档 https://leafletjs.com/reference.html

1.安装

npm install leaflet --s
npm i leaflet-draw --s

2.利用leaftlet引入地图

import * as L from 'leaflet'
import 'leaflet-draw'

初始化地图

<template>
  <div class="left-let-page">
    <div id="map"></div>
  </div>
</template>
<script>
export default {
  data () {
    return {
      map: null
    }
  },
  mounted () {
    this.initDate()
  },
  methods: {
    initDate () {
      let map = L.map("map", {
        minZoom: 3,
        maxZoom: 14,
        center: [40.02404009136253, 116.50641060224784], // 地图中心
        zoom: 14, //缩放比列
        zoomControl: false, //禁用 + - 按钮
        doubleClickZoom: false, // 禁用双击放大
        attributionControl: false, // 移除右下角leaflet标识
        crs: L.CRS.EPSG3857
      });
      this.map = map;    //data上需要挂载
      window.map = map;
      L.tileLayer(
        "http://webrd01.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=7&x={x}&y={y}&z={z}"
      ).addTo(map);
    }
  }
}
</script>
<style scoped lang='less'>
.left-let-page {
  #map {
    width: 100%;
    height: 100vh;
    margin: auto;
  }
}
</style>
3.引入百度地图

首先引入两个自定地图坐标系proj4leaflet+proj4转换插件

安装
npm install proj4 --save
npm install proj4leaflet --save
在assets目录下新建文件夹并创建tileLayer.baidu.js,编写百度地图底图调用插件代码:
/*
*tileLayer.baidu.js
*/
// 引用
// require('proj4')
// require('proj4leaflet')
import 'proj4';
import 'proj4leaflet';
import * as L from 'leaflet';
// const titleD = 'http://127.0.0.1:8886/{z}/{x}/{y}.png'
// const titleD = 'https://api.map.baidu.com/getscript?v=3.0&ak=7pQwLpGQZr0SdQ3vlDp8gu7ExEqjKRG1'
const titleD = 'http://online{s}.map.bdimg.com/onlinelabel/?qt=tile&x={x}&y={y}&z={z}&styles='

var urlPath = titleD;
//请引入 proj4.js 和 proj4leaflet.js
L.CRS.Baidu = new L.Proj.CRS('EPSG:900913', '+proj=merc +a=6378206 +b=6356584.314245179 +lat_ts=0.0 +lon_0=0.0 +x_0=0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +wktext  +no_defs', {
  resolutions: function () {
    let level = 19
    var res = [];
    res[0] = Math.pow(2, 18);
    for (var i = 1; i < level; i++) {
      res[i] = Math.pow(2, (18 - i))
    }
    return res;
  }(),
  origin: [0, 0],
  bounds: L.bounds([20037508.342789244, 0], [0, 20037508.342789244])
});

L.tileLayer.baidu = function (option) {
  option = option || {};

  var layer;
  var subdomains = '0123456789';
  switch (option.layer) {
    //单图层
    case "vec":
    default:
      layer = L.tileLayer(urlPath, {
        name: option.name, subdomains: subdomains, tms: true
      });

      // layer = L.tileLayer('http://online{s}.map.bdimg.com/onlinelabel/?qt=tile&x={x}&y={y}&z={z}&styles=' + (option.bigfont ? 'ph' : 'pl') + '&scaler=1&p=1', {
      //   name: option.name, subdomains: subdomains, tms: true
      // });
      break;
    case "img_d":
      layer = L.tileLayer('http://shangetu{s}.map.bdimg.com/it/u=x={x};y={y};z={z};v=009;type=sate&fm=46', {
        name: option.name, subdomains: subdomains, tms: true
      });
      break;
    case "img_z":
      layer = L.tileLayer('http://online{s}.map.bdimg.com/tile/?qt=tile&x={x}&y={y}&z={z}&styles=' + (option.bigfont ? 'sh' : 'sl') + '&v=020', {
        name: option.name, subdomains: subdomains, tms: true
      });
      break;

    case "custom"://Custom 各种自定义样式
      //可选值:dark,midnight,grayscale,hardedge,light,redalert,googlelite,grassgreen,pink,darkgreen,bluish
      option.customid = option.customid || 'midnight';
      // layer = L.tileLayer('http://api{s}.map.bdimg.com/customimage/tile?&x={x}&y={y}&z={z}&scale=1&customid=' + option.customid, {
      //     name: option.name, subdomains: "012", tms: true
      // });
      layer = L.tileLayer(urlPath, {
        name: option.name, subdomains: subdomains, tms: true
      });
      break;

    case "time"://实时路况
      var time = new Date().getTime();
      layer = L.tileLayer('http://its.map.baidu.com:8002/traffic/TrafficTileService?x={x}&y={y}&level={z}&time=' + time + '&label=web2D&v=017', {
        name: option.name, subdomains: subdomains, tms: true
      });
      break;

    //合并
    case "img":
      layer = L.layerGroup([
        L.tileLayer.baidu({ name: "底图", layer: 'img_d', bigfont: option.bigfont }),
        L.tileLayer.baidu({ name: "注记", layer: 'img_z', bigfont: option.bigfont })
      ]);
      break;
  }
  return layer;
};
使用百度地图地图
//引用tileLayer.baidu.js
import "@/assets/tileLayer.baidu.js"// 初始化地图
        ininMap() {
               let map = L.map("map", {
                    minZoom: 3,
                    maxZoom: 18,
                    center: [40.02404009136253, 116.50641060224784], // 地图中心
                    zoom: 8,
                    zoomControl: false,
                    attributionControl: true,
                    crs: L.CRS.Baidu
                });
                this.map = map;
                L.tileLayer.baidu({ layer: 'vec' }).addTo(map);
        },
4.利用leaflet-draw实现地图交互
// 初始化绘制控件
        initDrawCtrl() {
            var editableLayers =new L.FeatureGroup();
            this.map.addLayer(editableLayers);
            //初始化绘制控件
            this.drawControl = new L.Control.Draw({
                position: 'topright',//控件位置 'topleft'(默认), 'topright', 'bottomleft' or 'bottomright'
                draw: {
                    polyline: true,
                    polygon: true,
                    rectangle: true,
                    circle: true,
                    marker: true,
                },
                edit:{
                    featureGroup:editableLayers,
                    remove:false
                }
            }).addTo(this.map);// 要添加到 L.map 对象中
            // 添加绘制完监听事件
            this.map.on(L.Draw.Event.CREATED, this.drawCreatedBack);
            // 结束绘制监听
            this.map.on(L.Draw.Event.DRAWSTOP, function() {
                console.log('结束绘制')
            });
        },
 drawCreatedBack(e) {
            // 绘制的图形图层对象
            let drawLayer = e.layer;
            // 判断当前没有图层组,需先添加
            if(!this.drawLayerGrounp) {
                //图层组
                this.drawLayerGrounp = new L.FeatureGroup();
                // 添加
                this.map.addLayer(this.drawLayerGrounp);
            }
            // 添加到图层组
            this.drawLayerGrounp.addLayer(drawLayer);
                //以下代码为获取框选图形顶点坐标
                var locationArray = e.layer.getLatLngs()[0];
                let polygonArray = Array();
                var midArray = Array();
                var firstX = locationArray[0].lat;
                var firstY = locationArray[0].lng;
                for(var i =0;i<locationArray.length;i++){
                    var x = locationArray[i].lat;
                    var y = locationArray[i].lng;
                    midArray.push(x);
                    midArray.push(y);
                    polygonArray.push(midArray);
                    midArray = Array();
                }
                midArray.push(firstX);
                midArray.push(firstY);
                polygonArray.push(midArray);//我们要的就是这个数组
                let polygon = L.polygon(polygonArray);
                console.log(polygon)
        },
5.复现已经绘制好的区域
drawArea(){
            var latlngs = [[39.98335556743195,116.38727241416927],[39.98364840496984, 116.42397156518888],[39.95423178384607, 116.42408778347149],[39.95490801733468, 116.37905853264955]];
            var polygon = L.polygon(latlngs, {color: 'red'}).addTo(this.map);
            this.map.fitBounds(polygon.getBounds());
        }
6.效果展示
效果

相关文章

网友评论

      本文标题:利用 leaftlet+leaflet-draw 开发交互式地图

      本文链接:https://www.haomeiwen.com/subject/dvnwkrtx.html