SunZehao 7 mesiacov pred
rodič
commit
f9f0e51d60

+ 1 - 0
src/views/mapAnalysis/index.vue

@@ -168,6 +168,7 @@ const initDrawTooltip = () => {
   L.drawLocal.draw.toolbar.buttons.polyline = '绘制-线'
   L.drawLocal.draw.toolbar.buttons.polygon = '绘制-多边形区域'
   L.drawLocal.draw.toolbar.buttons.circle = '绘制-圆形区域'
+  L.drawLocal.draw.toolbar.buttons.rectangle = '绘制-方形区域'
   L.drawLocal.draw.toolbar.buttons.marker = '绘制-定点标记'
   L.drawLocal.draw.toolbar.buttons.circlemarker = '绘制-定点圆形标记'
   L.drawLocal.edit.toolbar.actions.save.text = '保存'

+ 0 - 188
src/views/mapAnalysis/mapjs2.vue

@@ -1,188 +0,0 @@
-<template>
-  <div>
-    <div id="map" class="map-main"></div>
-    <div class="btn-list">
-      <button @click="initDrawCtrl">初始化绘制控件</button><br />
-      <button @click="destoryDrawCtr">销毁绘制控件</button><br />
-      <button @click="startDraw(0)">点</button>
-      <button @click="startDraw(1)">圆</button>
-      <button @click="startDraw(2)">线</button>
-      <button @click="startDraw(3)">矩形</button>
-      <button @click="startDraw(4)">多边形</button>
-      <button @click="stopDraw">清除</button>
-    </div>
-  </div>
-</template>
- 
-<script>
-import 'leaflet'
-import 'leaflet-draw'
-
-export default {
-  data() {
-    return {
-      // L.map 对象
-      map: null,
-      // L.Control.Draw 控件对象
-      drawControl: null,
-      // 绘制对象
-      drawObj: null,
-      // 图形图层组
-      drawLayerGrounp: null
-    }
-  },
-  methods: {
-    // 启动绘制
-    startDraw(idx) {
-      // 先取消
-      if (this.drawObj) {
-        this.drawObj.disable()
-      }
-      switch (idx) {
-        case 0: {
-          // 点
-          this.drawObj = new L.Draw.Marker(this.map, this.drawControl.options.draw.marker)
-          break
-        }
-        case 1: {
-          // 圆
-          this.drawObj = new L.Draw.Circle(this.map, this.drawControl.options.draw.circle)
-          break
-        }
-        case 2: {
-          // 线
-          this.drawObj = new L.Draw.Polyline(this.map, this.drawControl.options.draw.polyline)
-          break
-        }
-        case 3: {
-          // 矩形
-          this.drawObj = new L.Draw.Rectangle(this.map, this.drawControl.options.draw.rectangle)
-          break
-        }
-        case 4: {
-          // 多边形
-          this.drawObj = new L.Draw.Polygon(this.map, this.drawControl.options.draw.polygon)
-          break
-        }
-      }
-      // 启动
-      this.drawObj.enable()
-    },
-    //清除绘制
-    stopDraw() {
-      // 删除全部绘制的图层
-      if (this.drawLayerGrounp) {
-        this.drawLayerGrounp.clearLayers()
-      }
-      // 取消绘制操作
-      this.drawObj.disable()
-    },
-    // 初始化地图
-    ininMap() {
-      // 初始化地图容器并显天地图
-      this.map = L.map('map', {
-        //参考坐标系
-        crs: L.CRS.EPSG4326,
-        //不添加属性说明控件
-        attributionControl: false,
-        //限制显示地理范围
-        maxBounds: L.latLngBounds(L.latLng(-180, -180), L.latLng(180, 180))
-      })
-
-      // 设置范围(这里是武汉)
-      this.map.setView([30.59, 114.32], 10)
-      // 矢量图+注记
-      // let mapTypes = ['vec_c', 'cva_c'];
-      // 影像图+注记
-      let mapTypes = ['img_c', 'cia_c']
-      // 天地图 token
-      let tdtToken = 'xxxxxxxxxxxxxxxx'
-      let layers = []
-      for (let i = 0, len = mapTypes.length; i < len; i++) {
-        let tdtUrl = `http://t0.tianditu.gov.cn/DataServer?T=${mapTypes[i]}&x={x}&y={y}&l={z}&tk=${tdtToken}`
-        let layer = L.tileLayer(tdtUrl, {
-          zoomOffset: 1,
-          noWrap: true,
-          bounds: [
-            [-90, -180],
-            [90, 180]
-          ]
-        })
-        layers.push(layer)
-      }
-      L.layerGroup(layers).addTo(this.map)
-    },
-    // 交互绘制回调
-    drawCreatedBack(e) {
-      console.log('绘制完成', e)
-      // 绘制的图形图层对象
-      let drawLayer = e.layer
-      // 判断当前没有图层组,需先添加
-      if (!this.drawLayerGrounp) {
-        //图层组
-        this.drawLayerGrounp = new L.FeatureGroup()
-        // 添加
-        this.map.addLayer(this.drawLayerGrounp)
-      }
-      // 添加到图层组
-      this.drawLayerGrounp.addLayer(drawLayer)
-    },
-    // 初始化绘制控件
-    initDrawCtrl() {
-      //初始化绘制控件
-      this.drawControl = new L.Control.Draw({
-        position: 'topright', //控件位置 'topleft'(默认), 'topright', 'bottomleft' or 'bottomright'
-        draw: {
-          polyline: true,
-          polygon: true,
-          rectangle: true,
-          circle: true,
-          marker: true
-        }
-      }).addTo(this.map) // 要添加到 L.map 对象中
-      // 添加绘制完监听事件
-      this.map.on(L.Draw.Event.CREATED, this.drawCreatedBack)
-    },
-    // 销毁绘制控件
-    destoryDrawCtr() {
-      // L.Control.Draw 控件对象
-      this.drawControl = null
-      // 绘制对象
-      this.drawObj = null
-      // 删除全部绘制的图层
-      if (this.drawLayerGrounp) {
-        this.drawLayerGrounp.clearLayers()
-      }
-      // 取消绘制完监听事件,避免在真正开发中,其它地方也监听了 CREATED 事件
-      this.container.map.off(L.Draw.Event.CREATED, this.drawCreatedBack)
-    }
-  },
-  mounted() {
-    // 初始化地图
-    this.ininMap()
-    // 初始化绘制控件
-    this.initDrawCtrl()
-  }
-}
-</script>
- 
-<style lang="stylus" scoped>
-@import '~leaflet/dist/leaflet.css';
-@import '~leaflet-draw/dist/leaflet.draw.css';
-
-.map-main {
-  position: absolute;
-  top: 0;
-  left: 0;
-  right: 0;
-  bottom: 0;
-  background: #CCC;
-}
-
-.btn-list {
-  z-index: 2000;
-  position: absolute;
-  top: 2px;
-  left: 80px;
-}
-</style>

+ 0 - 375
src/views/mapAnalysis/testMap.vue

@@ -1,375 +0,0 @@
-<template>
-  <!-- leaflet 地图组件,内嵌于页面中
-      功能: 支持手动绘制区域、编辑区域、删除区域,以及渲染 geoJson 面图
-   -->
-  <div class="map-box">
-    <div :id="id" :style="{ width, height }" />
-    <div v-show="isShowClearBtn" @click="clearAreaLayer()" class="button" title="删除已保存的区域">
-      <a-icon type="delete" />
-    </div>
-  </div>
-</template>
-<script>
-import * as L from 'leaflet'
-import 'leaflet/dist/leaflet.css'
-import 'proj4leaflet'
-import 'leaflet.chinatmsproviders'
-import '@/assets/map/leaflet.ChineseTmsProviders'
-import 'leaflet-draw'
-export default {
-  name: 'TxMap',
-  props: {
-    id: {
-      type: String,
-      default: () => ''
-    },
-    width: {
-      type: String,
-      default: () => '100%'
-    },
-    height: {
-      type: String,
-      default: () => '280px'
-    },
-    center: {
-      type: Object,
-      default: () => {
-        return {
-          latitude: '36.70261',
-          longitude: '119.16160'
-        }
-      }
-    },
-    geoJson: {
-      type: String,
-      default: () => ''
-    },
-    // 操作类型: add-新增  edit-编辑
-    operateType: {
-      type: String,
-      default: () => ''
-    },
-    visible: {
-      type: Boolean,
-      default: () => false
-    }
-  },
-  data() {
-    return {
-      isShowClearBtn: false,
-      // L.map 对象
-      map: null,
-      // L.Control.Draw 控件对象
-      drawControl: null,
-      // 图形图层组
-      drawLayerGroup: null
-    }
-  },
-  watch: {
-    visible(newVal) {
-      if (newVal) {
-        if (this.isAdd()) {
-          // 新增
-          this.init()
-          this.clearAreaLayer()
-        } else if (this.isEdit()) {
-          // 编辑
-          this.init()
-          this.addLayers(this.geoJson)
-        } else {
-          // 查看详情,没有绘图控件
-          this.init('noControl')
-          this.addLayers(this.geoJson)
-        }
-        this.handleClearBtn()
-      }
-    }
-  },
-  mounted() {
-    if (this.isDetail()) {
-      this.init('noControl')
-    } else {
-      this.init()
-    }
-
-    this.handleClearBtn()
-
-    this.addLayers(this.geoJson)
-  },
-  methods: {
-    init(data) {
-      // 初始化地图
-      this.initMap()
-      if (data !== 'noControl') {
-        // 初始化绘制控件
-        this.initDrawCtrl()
-      }
-    },
-
-    initMap() {
-      const { latitude, longitude } = this.center
-      if (!this.map) {
-        this.map = L.map(document.getElementById(this.id), {
-          center: [latitude || '36.70261', longitude || '119.16160'],
-          zoom: 9,
-          //不添加属性说明控件
-          attributionControl: false
-        })
-      }
-
-      this.tileLayer = [
-        L.tileLayer.chinaProvider('GaoDe.Normal.Map', {
-          maxZoom: 16,
-          minZoom: 4
-        })
-      ]
-
-      this.tileLayer.map((layer) => {
-        this.map.addLayer(layer)
-      })
-    },
-
-    handleClearBtn() {
-      if (this.isAdd() || this.isDetail()) {
-        this.isShowClearBtn = false
-      } else {
-        if (this.hasGeoJson()) {
-          this.isShowClearBtn = true
-        } else {
-          this.isShowClearBtn = false
-        }
-      }
-    },
-
-    // 初始化绘制控件
-    initDrawCtrl() {
-      // 判断当前没有图层组,需先添加
-      if (!this.drawLayerGroup) {
-        //图层组
-        this.drawLayerGroup = new L.FeatureGroup()
-      }
-
-      if (!this.map.hasLayer(this.drawLayerGroup)) {
-        // 添加
-        this.map.addLayer(this.drawLayerGroup)
-      }
-
-      // 初始化绘制控件
-      if (!this.drawControl) {
-        this.initDrawTooltip()
-        this.drawControl = new L.Control.Draw({
-          position: 'topleft', // 控件位置 'topleft'(默认), 'topright', 'bottomleft' or 'bottomright'
-          draw: {
-            polygon: true,
-            polyline: false,
-            rectangle: false,
-            circle: false,
-            marker: false,
-            circlemarker: false
-          },
-          edit: {
-            // 绘制图层
-            featureGroup: this.drawLayerGroup,
-            // 图形编辑控件
-            edit: true,
-            // 图形删除控件
-            remove: true
-          }
-        }).addTo(this.map) // 要添加到 L.map 对象中
-
-        this.Edit = new L.EditToolbar.Edit(this.map, { featureGroup: this.drawLayerGroup })
-
-        this.Delete = new L.EditToolbar.Delete(this.map, { featureGroup: this.drawLayerGroup })
-      }
-
-      // 添加绘制完监听事件
-      this.map.on(L.Draw.Event.CREATED, this.drawCreatedBack)
-      // 删除事件
-      this.map.on(L.Draw.Event.DELETED, this.handleDelete)
-      // 编辑事件
-      this.map.on(L.Draw.Event.EDITED, this.handleEdited)
-    },
-
-    // 交互绘制回调
-    drawCreatedBack(e) {
-      // 绘制的图形图层对象
-      let drawLayer = e.layer
-
-      // 添加到图层组
-      this.drawLayerGroup.addLayer(drawLayer)
-
-      let { lat, lng } = drawLayer.getCenter()
-      lat = parseFloat(lat).toFixed(5)
-      lng = parseFloat(lng).toFixed(5)
-      // 更新中心点坐标
-      this.$emit('submitCenterMarker', lat, lng)
-
-      this.$emit('submitLatlngs', this.drawLayerGroup._layers, this.isHasAreaLayer())
-    },
-
-    handleDelete() {
-      this.$emit('submitLatlngs', this.drawLayerGroup._layers, this.isHasAreaLayer())
-    },
-
-    handleEdited() {
-      this.$emit('submitLatlngs', this.drawLayerGroup._layers, this.isHasAreaLayer())
-    },
-
-    isHasAreaLayer() {
-      let flag
-      if (this.areaLayer) {
-        flag = this.map.hasLayer(this.areaLayer)
-      } else {
-        flag = false
-      }
-      return flag
-    },
-
-    // 改变绘制控件的按钮文本及提示语
-    initDrawTooltip() {
-      L.drawLocal.draw.handlers.polygon = {
-        tooltip: {
-          start: '点击地图开始绘制多边形',
-          cont: '继续选择',
-          end: '点击第一个顶点完成绘制'
-        }
-      }
-      L.drawLocal.draw.toolbar.buttons.polygon = '绘制'
-      L.drawLocal.edit.toolbar.actions.save.text = '保存'
-      L.drawLocal.edit.toolbar.actions.save.title = '保存'
-      L.drawLocal.edit.toolbar.actions.cancel.text = '取消'
-      L.drawLocal.edit.toolbar.actions.cancel.title = '取消'
-      L.drawLocal.edit.toolbar.actions.clearAll.text = '清除全部'
-      L.drawLocal.edit.toolbar.actions.clearAll.title = '清除全部'
-      L.drawLocal.edit.toolbar.buttons.editDisabled = '暂无区域可编辑'
-      L.drawLocal.edit.toolbar.buttons.removeDisabled = '暂无区域可删除'
-      L.drawLocal.edit.handlers.remove.tooltip.text = '选中一个区域去清除'
-      L.drawLocal.edit.toolbar.buttons.edit = '编辑'
-      L.drawLocal.edit.toolbar.buttons.remove = '删除'
-      L.drawLocal.edit.toolbar.buttons.cancel = '取消'
-      L.drawLocal.edit.toolbar.buttons.save = '保存'
-      L.drawLocal.draw.toolbar.actions.text = '取消'
-      L.drawLocal.draw.toolbar.actions.title = '取消绘制'
-      L.drawLocal.draw.toolbar.finish.text = '完成'
-      L.drawLocal.draw.toolbar.finish.title = '完成绘制'
-      L.drawLocal.draw.toolbar.undo.text = '撤销'
-      L.drawLocal.draw.toolbar.undo.title = '撤销'
-      L.drawLocal.edit.handlers.edit.tooltip.subtext = '点击取消以撤消更改'
-      L.drawLocal.edit.handlers.edit.tooltip.text = '拖动标记以编辑图形'
-    },
-
-    // 销毁地图以及绘制控件
-    destroyDrawCtrl() {
-      // 移除地图上的控制组件
-      if (this.drawControl) {
-        this.map.removeControl(this.drawControl)
-      }
-      // L.Control.Draw 控件对象
-      this.drawControl = null
-      // 删除全部绘制的图层
-      if (this.drawLayerGroup) {
-        this.drawLayerGroup.clearLayers()
-      }
-      // 移除已保存的区域
-      if (this.map.hasLayer(this.areaLayer)) {
-        this.map.removeLayer(this.areaLayer)
-      }
-
-      // 取消监听事件,避免其它地方也监听了 CREATED 事件
-      this.map.off(L.Draw.Event.CREATED, this.drawCreatedBack)
-      this.map.off(L.Draw.Event.DELETED, this.handleDelete)
-      this.map.off(L.Draw.Event.EDITED, this.handleEdited)
-      // 销毁该地图
-      this.map.remove()
-      this.map = null
-    },
-
-    addLayers(geoJson) {
-      if (this.hasGeoJson()) {
-        this.areaLayer = L.geoJSON(JSON.parse(geoJson), {
-          style: (feature) => {
-            return {
-              fillOpacity: 0.3,
-              weight: 2,
-              fillColor: '#40a9ff'
-            }
-          }
-        })
-
-        if (!this.map.hasLayer(this.areaLayer)) {
-          this.map.addLayer(this.areaLayer)
-        }
-
-        this.map.fitBounds(this.areaLayer.getBounds())
-
-        // this.Delete.options.featureGroup._layers = this.areaLayer._layers
-        // this.Edit.options.featureGroup._layers = this.areaLayer._layers
-        // this.map.removeControl(this.drawControl)
-        // L.Control.Draw 控件对象
-        // this.drawControl = null
-        // this.initDrawCtrl()
-      }
-    },
-
-    hasGeoJson() {
-      return (
-        this.geoJson &&
-        this.geoJson.length > 0 &&
-        JSON.parse(this.geoJson).features &&
-        JSON.parse(this.geoJson).features.length > 0
-      )
-    },
-
-    // 删除已保存的区域
-    clearAreaLayer() {
-      if (this.map.hasLayer(this.areaLayer)) [this.map.removeLayer(this.areaLayer)]
-      this.isShowClearBtn = false
-      this.$emit('submitLatlngs', [], false)
-    },
-
-    isAdd() {
-      return this.operateType === 'add'
-    },
-
-    isEdit() {
-      return this.operateType === 'edit'
-    },
-
-    isDetail() {
-      return this.operateType === 'detail'
-    }
-  }
-}
-</script>
-
-<style scoped lang="scss">
-@import '~leaflet-draw/dist/leaflet.draw.css';
-  .map-box {
-    width: auto;
-    height: auto;
-    position: relative;
-  }
-  .button {
-    position: absolute;
-    top: 203px;
-    left: 10px;
-    z-index: 1001;
-    width: 34px;
-    padding: 0;
-    height: 30px;
-    background: #ffffff;
-    line-height: 30px;
-    text-align: center;
-    border: 1px solid #a79f9f;
-    border-radius: 3px;
-    cursor: pointer;
-    &:hover {
-      background: #efefef;
-    }
-  }
-  ::v-deep .ant-btn:hover,
-  ::v-deep .ant-btn:focus {
-    color: rgba(0, 0, 0, 0.65);
-    ">#fff;
-  }
-</style>