Baidu offline map overlays are dynamically added (polygons, markers)

 Introduction method reference:Baidu map offline map realizes drawing polygons and echoing polygon areas_Holly31's blog-CSDN blog

 Red editing point: Click on the map to add a new one or assign it based on data. You can drag or click to move it.

ps: Because the el-scrollbar is added to the outer layer of the map, it will interfere with the zooming of the map, so I wrote a method to zoom.

offlineMarke.vue

<template>
  <div class="markmap">
    <div :id="mapId" class="allmap" />
  </div>
</template>

<script>
export default {
  props: {
    canAddMarker: {
      type: Boolean,
      default: false,
    },
    searchKeyword: String,
    strokeColor: {
      type: String,
      default: "#2A8DFF",
    },
    path: {
      type: String,
      default:"",
    },
    markers: {
      type: Array,
      default:()=>[],
    },
    pcenter: {
      type: Object,
      default: () => ({
        lng: 114.97731018066408,
        lat: 25.8246784210205,
      }),
    },
  },
  components: {},

  data() {
    return {
      markersOverlay:[],
      mapId: "map" + new Date().getTime(),
      zoom: 13,
      center: {
        lng: 114.97731018066408,
        lat: 25.8246784210205,
      },
    };
  },
  watch: {
    searchKeyword: {
      handler(val) {
        if (val) {
          this.localSearchFun();
        }
      },
    },
    pcenter: {
      handler(val) {
         const point=new BMap.Point(val.lng,val.lat);
         this.map.setCenter(point, );
      },
    },
    markers: {
      handler(arr) {
        if(arr&&arr.length>0){
          if(this.markersOverlay&&this.markersOverlay.length>0){
            this.markersOverlay.forEach(item=>{
              this.map.removeOverlay( item);
            })
          }
          this.$nextTick(() => {
            arr.forEach(item=>{
            this.customMarkerOverlay(item);
          })
          },1000)
          
        }
      },
      deep: true,
      immediate:true
    },
    path: {
      handler(val,oldVal) {
        if (val) {
           this.$nextTick(() => {
            this.drawDefault(val);
          }, 1000);
        }
      },
      immediate: true,
      deep: true,
    },
  },
  computed: {
    
  },
  created() {
     this.mapId = "map" + new Date().getTime();
  },
  mounted() {
    this.initMap();
  },

  methods: {
    //默认多边形
    drawDefault(points) {
      if (points) {
        let newPonits = [];
        let arr = points.split(";");
        arr.forEach((item) => {
          let itemArr = item.split(",");
          newPonits.push(new BMap.Point(itemArr[0], itemArr[1]));
        });
        const polygon = new BMap.Polygon(newPonits, {
          strokeColor: this.strokeColor,
          strokeWeight: 4,
          strokeOpacity: 1,
          fillColor: this.strokeColor,
          fillOpacity: 0.2,
        });
        this.map.removeOverlay(this.polygonOverlay);
        this.map.addOverlay(polygon);
        this.map.setCenter(newPonits[0]); 
        this.polygonOverlay=polygon;
      }
    },
    //地图初始化
    initMap() {
      const _this = this;
      const point = new BMap.Point(114.97731018066408, 25.8246784210205);
      _this.map = new BMap.Map(this.mapId, { enableMapClick: false,minZoom:4,maxZoom:19 }); // 创建Map实例,GL版命名空间为BMap(鼠标右键控制倾斜角度)
      _this.map.centerAndZoom(point, this.zoom); // 初始化地图,设置中心点坐标和地图级别
      /*  _this.map.enableScrollWheelZoom(true);  */ // 开启鼠标滚轮缩放
      _this.suofang();
      /*   _this.cerateMarker(point);   */

      this.map.addControl(new BMap.NavigationControl({anchor:BMAP_ANCHOR_BOTTOM_LEFT}));//type:BMAP_NAVIGATION_CONTROL_ZOOM type:BMAP_NAVIGATION_CONTROL_SMALL,enableGeolocation:true
 
      this.map.addControl(new BMap.GeolocationControl({anchor:BMAP_ANCHOR_BOTTOM_RIGHT}));
    
      this.map.addEventListener("click", function (e) {
          _this.mapClickFun(e);
      });
    },
    /* 标记点 */
    createMarkerDOM(markerObj) {
      const img = document.createElement("img");
      img.style.height = "50px";
      img.style.width = "50px";
      img.src = markerObj.src;
      img.draggable = markerObj.dragging;
      return img;
    },
    customMarkerOverlay(markerObj) {
      const _this=this;
      let myIcon = new BMap.Icon(markerObj.icon, new BMap.Size(45, 45));
      let pt = new BMap.Point(markerObj.lng, markerObj.lat);
      var marker = new BMap.Marker(pt, {
        icon: myIcon,
        enableDragging: markerObj.dragging,
        oType:'marker',
       offset:markerObj.offset?new BMap.Size(...markerObj.offset):new BMap.Size(5,-17)
      });
      this.map.addOverlay(marker);
      this.markersOverlay.push(marker);
      // 绑定点击事件
      marker.addEventListener("click", function (e) {
        console.log("eeee", e);
      });
      //绑定拖拽事件
      marker.addEventListener("dragend", function (e) {
        _this.$emit("updateMarkerLocal", e.point);
      });
    },
    cerateMarker(point) {
      const marker = new BMap.Marker(point);
      // 将标记点添加到地图上
      this.map.addOverlay(marker);
    },
    handlerMap({ BMap, map }) {
      this.BMap = BMap;
      this.map = map;
    },
    //点击地图事件 增加标记点
    mapClickFun(ev) {
       
      if (this.canAddMarker) {
        this.$emit("updateMarkerLocal", ev.point);
      }
    },
    //缩放
    suofang() {
      document.querySelector(".markmap").onmousewheel = (e) => {
        e = e || window.event;
        if (e.stopPropagation) {
          //这是取消冒泡
          e.stopPropagation();
        } else {
          e.cancelBubble = true;
        }
        if (e.preventDefault) {
          //这是取消默认行为,要弄清楚取消默认行为和冒泡不是一回事
          e.preventDefault();
        } else {
          e.returnValue = false;
        }
        //放大 getZoom返回地图当前缩放级别
        if (e.wheelDelta > 0) {
          this.zoom = this.zoom + 1;
          if (this.zoom > 19) {
            this.zoom=19;
          }
        }
        //缩小
        if (e.wheelDelta < 0) {
          e.cancelBubble = true;
          this.zoom = this.zoom - 1;
          if (this.zoom < 4) {
            this.zoom = 4;
          }
        }
        this.map.setZoom(this.zoom);
      };
    },
    //拖拽标记
    markerDragendEvent(e) {
      const _this = this;
      _this.$emit("updateMarkerLocal", e.point);
    },
    //关键词搜索
    localSearchFun(searchWord) {
      const _this = this;
      this.$nextTick(() => {
        const local = new BMap.LocalSearch(this.map, {
          onSearchComplete: function (e) {
            _this.$emit("searchcomplete", e);
          },
        });
        local.search(searchWord ? searchWord : this.searchKeyword);
      });
    },
  },
};
</script>
<style lang="scss" scoped>
.markmap {
  width: 800px;
  height: 500px;
  .allmap {
    width: 100%;
    height: 100%;
  }
}
</style>

Page usage

<template>
  <div class="">
    <offlineMarke
      ref="mydrawMap"
      class="mymap-wrap"
      :canAddMarker="canAddMarker"
      :path="path"
      :strokeColor="strokeColor"
      :pcenter="center"
      :markers="markers"
      @updateMarkerLocal="updateMarkerLocal"
    ></offlineMarke>
  </div>
</template>

<script>
import offlineMarke from "@/components/Map/offlineMarke";
export default {
  props: [],
  components: { offlineMarke },
  data() {
    return {
      canAddMarker: true,
      strokeColor: "#FF6B36",
      center:{
        lng: "114.933625",
          lat: "25.85190",
      },
      path: "114.92785540582945,25.83652466645269;114.92823026067752,25.847650021588933;114.93326455552047,25.84679557530646;114.94444120792562,25.847283346808027;114.94666935084885,25.846470393187857;114.94991319176417,25.844372292159633;114.9536417373817,25.840323628122093;114.95646285382479,25.83860005841268;114.96159150781574,25.83115605191992;114.96356808621543,25.824976622119365;114.9643227797862,25.82133385975571;114.9613758810813,25.81834150683285;114.9581414800636,25.816454984607688;114.95318206516998,25.81499128286883;114.950630482145,25.813495035728792;114.94502418704789,25.80816043559642;114.93953141347649,25.80412817087722;114.93648047520966,25.807707561717777;114.94762118982572,25.816164775470398;114.93985862738357,25.82410099603871;114.94194301915044,25.826117491923867;114.94172739241593,25.839321438580683;114.93834924024202,25.839256398119232;114.92785540582945,25.83652466645269",
      markers: [
        {
          lng: "114.933625",
          lat: "25.85190",
          icon: "",
        },
        {
          lat: "25.826759824838696",
          lng: "114.94770203106496",
          dragging: true,
          icon: "",
          offset: [3, -18],
        },
      ],
    };
  },
  created() {},
  mounted() {},
  methods: {
    updateMarkerLocal(point) {
        this.markers[1].lat=point.lat;
        this.markers[1].lng=point.lng;
    },
  },
};
</script>
<style lang="scss" scoped>
</style>

Guess you like

Origin blog.csdn.net/Holly31/article/details/130305189