高德地图自定义折线矢量图形

实现的功能:通过点标记连接生成线 实现折线适量图形

进一步实现功能:1.对指定点进行拖拽

2.从多个点中删除指定点

// 初始化地图
      map.value = new AMap.Map('g-container', {
        resizeEnable: true,
        center: [longitude, latitude],
        layers: [
          // 卫星
          new AMap.TileLayer.Satellite(),
          // 路网
          new AMap.TileLayer.RoadNet(),
        ],
        zoom: 16, // 地图显示的缩放级别
        zooms: [0, 19], // 设置缩放级别范围为3至16
      })

map.value.on('click', (e: any) => {
        console.log('点击地图', e)
        table.value.ruleForm.LngLat.push([e.lnglat.lng, e.lnglat.lat])
        table.value.ruleForm.from.push({
         //需要上传的数据
        })
        map.value.clearMap() // 清理地图
        inMake(table.value.ruleForm.from.length)
        inLine(map.value)
      })

//将点标记在地图上
const markers: any = ref([])
const markerIndexs: any = ref(null)
const isMaker = ref(true)
const inMake = (length: any) => {
  // 先进行清空方便后续功能不出现重复点
  markers.value = []
  // 点击每个点选中显示在地图上
  table.value.ruleForm.from.forEach((i: any, index, arr) => {
    const markerContent =
      '' + '<div class="red-circle">' + `<span>${index + 1}</span>` + '</div>' + `<div class="close-btn" onclick="clearMarker(${index})">X</div>`
    const markerContent2 =
      '' + '<div class="red-circle2">' + `<span>${index + 1}</span>` + '</div>'
    const position = [i.lng || i.longitude, i.lat || i.latitude]
    console.log('markerContent2', markerContent2)
    const marker = new AMap.Marker({
      position: position,
      content: length - 1 === index ? markerContent2 : markerContent,
      offset: new AMap.Pixel(-19, -49),
      draggable: true,
    })
    markerIndexs.value = length
    marker.index = i
    map.value.add(marker)
    marker.on('click', function (e) {
      const markerIndex = markers.value.indexOf(this)
      console.log('标记点', markerIndex)
      if (markerIndex !== -1) {
        // alert('点击的是第 ' + (markerIndex + 1) + ' 个点');
        inMake(markerIndex + 1)
        markerIndexs.value = markerIndex + 1
      }
    })

//实现点拖拽功能
    marker.on('dragend', (event) => {
      console.log('event', event)
      table.value.ruleForm.from[index].longitude = event.lnglat.lng
      table.value.ruleForm.from[index].latitude = event.lnglat.lat
      table.value.ruleForm.from[index].point = {
        point: event.lnglat.lng + ',' + event.lnglat.lat,
      }
      table.value.ruleForm.LngLat[index] = [event.lnglat.lng, event.lnglat.lat]
      map.value.clearMap()
      inMake(markerIndexs.value)
      inLine(map.value)
    })

// 将标记添加到标记数组
    markers.value.push(marker)
    if (isMaker.value) {
      map.value.setFitView()
      isMaker.value = false
    }
  })
}

//根据点生成线
const polyline: any = ref(null)
const inLine = (map: any) => {
  polyline.value = new AMap.Polyline({
    path: table.value.ruleForm.LngLat,
    isOutline: true,
    outlineColor: '#ffeeff',
    borderWeight: 3,
    strokeColor: '#3366FF',
    strokeOpacity: 1,
    strokeWeight: 6,
    // 折线样式还支持 'dashed'
    strokeStyle: 'solid',
    // strokeStyle是dashed时有效
    strokeDasharray: [10, 5],
    lineJoin: 'round',
    lineCap: 'round',
    zIndex: 50,
    draggable: false,
  })
  polyline.value.setMap(map)
}

//删除对应点标记
window.clearMarker = (index:Number) => {
  console.log('点击删除', index)
  table.value.ruleForm.LngLat.splice(index, 1)
  table.value.ruleForm.from.splice(index, 1)
  map.value.clearMap()
  inMake(markerIndexs.value)
  inLine(map.value)
}
相关推荐
蟾宫曲3 小时前
在 Vue3 项目中实现计时器组件的使用(Vite+Vue3+Node+npm+Element-plus,附测试代码)
前端·npm·vue3·vite·element-plus·计时器
秋雨凉人心3 小时前
简单发布一个npm包
前端·javascript·webpack·npm·node.js
liuxin334455663 小时前
学籍管理系统:实现教育管理现代化
java·开发语言·前端·数据库·安全
qq13267029403 小时前
运行Zr.Admin项目(前端)
前端·vue2·zradmin前端·zradmin vue·运行zradmin·vue2版本zradmin
LCG元4 小时前
Vue.js组件开发-使用vue-pdf显示PDF
vue.js
魏时烟4 小时前
css文字折行以及双端对齐实现方式
前端·css
哥谭居民00015 小时前
将一个组件的propName属性与父组件中的variable变量进行双向绑定的vue3(组件传值)
javascript·vue.js·typescript·npm·node.js·css3
烟波人长安吖~5 小时前
【目标跟踪+人流计数+人流热图(Web界面)】基于YOLOV11+Vue+SpringBoot+Flask+MySQL
vue.js·pytorch·spring boot·深度学习·yolo·目标跟踪
2401_882726485 小时前
低代码配置式组态软件-BY组态
前端·物联网·低代码·前端框架·编辑器·web
web130933203985 小时前
ctfshow-web入门-文件包含(web82-web86)条件竞争实现session会话文件包含
前端·github