Vue-baidu-map覆盖物动态增加(多边形、标记点)

安装:npm install vue-baidu-map --save 

实现效果:

 页面增加标记及多边形等覆盖物,标记可点击及拖拽调整,同时也可通过关键词搜索获取获取经纬度,调整标记点位置,获取推荐几个地址,问题地址下拉选择其中一个地址等

marker.vue组件

<template>
  <div class="markmap">
    <baidu-map
      id="baiduMap"
      ak="123"
      class="baidu-map bm-view"
      :center="center"
      :zoom="zoom"
      :scroll-wheel-zoom="false"
      :mapClick="false"
      @ready="handlerMap"
      @click="mapClickFun"
    >
      <bm-marker
        :dragging="marker.dragging || false"
        v-for="(marker, index) of markers"
        :key="index"
        :position="{ lng: marker.lng, lat: marker.lat }"
        @click="lookDetail(marker)"
        @dragend="markerDragendEvent"
        :icon="{
          url: marker.icon
            ? marker.icon
            : 'http://api0.map.bdimg.com/images/marker_red_sprite.png',
          size: { width: 50, height: 65 },
        }"
      ></bm-marker>
      <bm-polygon
        v-if="path && path.length > 0"
        :path="path"
        :strokeColor="strokeColor"
      ></bm-polygon>
      <!--   <bm-panorama anchor="BMAP_ANCHOR_BOTTOM_RIGHT"></bm-panorama>  -->
      <bm-navigation anchor="BMAP_ANCHOR_BOTTOM_LEFT"></bm-navigation>
      <!--  <bm-scale  anchor="BMAP_ANCHOR_BOTTOM_RIGHT"></bm-scale> -->
      <BmGeolocation anchor="BMAP_ANCHOR_BOTTOM_RIGHT"></BmGeolocation>
      <!--  <bmLocalSearch v-if="searchKeyword" :autoViewport="true" :keyword="searchKeyword" :panel="false" :selectFirstResult="true" @searchcomplete="searchcomplete"></bmLocalSearch> -->
    </baidu-map>
  </div>
</template>
 
<script>
import BaiduMap from "vue-baidu-map/components/map/Map.vue";
import BmMarker from "vue-baidu-map/components/overlays/Marker.vue";
import BmPolygon from "vue-baidu-map/components/overlays/Polygon.vue";
import BmPanorama from "vue-baidu-map/components/controls/Panorama.vue";
import BmNavigation from "vue-baidu-map/components/controls/Navigation.vue";
import BmScale from "vue-baidu-map/components/controls/Scale.vue";
import BmGeolocation from "vue-baidu-map/components/controls/Geolocation.vue";
import BmLocalSearch from "vue-baidu-map/components/search/LocalSearch.vue";
export default {
  props: {
    canAddMarker: {
      type: Boolean,
      default: false,
    },
    searchKeyword: String,
    keyword: {
      type: [Array, String],
    },
    strokeColor: {
      type: String,
      default: "#2A8DFF",
    },
    path: {
      type: Array,
      default: () => [],
    },

    markers: {
      type: Array,
      default: () => [],
    },
    pcenter: {
      type: Object,
      default: () => ({
        lng: 114.97731018066408,
        lat: 25.8246784210205,
      }),
    },
  },
  components: {
    BaiduMap,
    BmMarker,
    BmPolygon,
    BmPanorama,
    BmNavigation,
    BmScale,
    BmGeolocation,
    BmLocalSearch,
  },
  watch: {
    searchKeyword: {
      handler(val) {
        if (val) {
          this.localSearchFun();
        }
      },
    },
    pcenter: {
      handler(val) {
        this.center = val;
      },
    },
  },
  data() {
    return {
      zoom: 13,
      center: {
        lng: 114.97731018066408,
        lat: 25.8246784210205,
      },
    };
  },
  created() {},
  mounted() {
    this.suofang();
  },
  methods: {
    handlerMap({ BMap, map }) {
      this.BMap = BMap;
      this.map = map;
    },
    //点击地图事件 增加标记点
    mapClickFun(e) {
      if (this.canAddMarker) {
        const _this = this;
        let geoc = new BMap.Geocoder();
        geoc.getLocation(e.point, function (rs) {
          _this.$emit("updateMarkerLocal", e.point, rs);
        });
      }
    },
    //缩放
    suofang() {
      document.querySelector(".bm-view").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;
          }
        }
      };
    },
    //拖拽标记  获取周边地址供选择
    markerDragendEvent(e) {
      console.log(e);
      const _this = this;
      let geoc = new BMap.Geocoder();
      geoc.getLocation(e.point, function (rs) {
        _this.$emit("updateMarkerLocal", e.point, rs);
      });
    },
    //关键词搜索
    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);
      });
    },
    lookDetail() {},
    searchcomplete(e) {},
  },
};
</script>
<style lang="scss" scoped>
.markmap {
  width: 800px;
  height: 500px;
  .baidu-map {
    width: 100%;
    height: 100%;
  }
}
</style>

页面

<template>
  <div class="">
    <el-form :model="form" label-width="155px">
      <el-form-item label="点击Map获取地址信息">
        <el-autocomplete
          class="myinput"
          v-model="form.address"
          :fetch-suggestions="queryAddressSearch"
          placeholder="请输入"
          @select="handleAddressSelect"
          :maxlength="20"
          clearable
        ></el-autocomplete>
      </el-form-item>
      <el-form-item label="关键搜索获取经纬度">
        <el-input
          v-model="form.address1"
          placeholder="请输入关键词搜索,如赣州市"
          maxlength="20"
        ></el-input>
      </el-form-item>
    </el-form>

    <markerMap
      ref="mydrawMap"
      class="mymap-wrap"
      :canAddMarker="canAddMarker"
      :path="path"
      :strokeColor="strokeColor"
      :pcenter="center"
      :markers="markers"
      :searchKeyword="form.address1"
      @searchcomplete="searchcomplete"
      @updateMarkerLocal="updateMarkerLocal"
    ></markerMap>
  </div>
</template>

<script>
import markerMap from "@/components/Map/marker";
export default {
  props: [],
  components: { markerMap },
  data() {
    return {
      form: {
        address: "",
      },
      canAddMarker: true,
      strokeColor: "#CC16EF",
      center: {
        lng: "114.933625",
        lat: "25.85190",
      },
      path: [
        { lng: 114.92785540582945, lat: 25.83652466645269 },
        { lng: 114.92823026067752, lat: 25.847650021588933 },
        { lng: 114.93326455552047, lat: 25.84679557530646 },
        { lng: 114.94444120792562, lat: 25.847283346808027 },
        { lng: 114.94666935084885, lat: 25.846470393187857 },
        { lng: 114.94991319176417, lat: 25.844372292159633 },
        { lng: 114.9536417373817, lat: 25.840323628122093 },
        { lng: 114.95646285382479, lat: 25.83860005841268 },
        { lng: 114.96159150781574, lat: 25.83115605191992 },
        { lng: 114.96356808621543, lat: 25.824976622119365 },
        { lng: 114.9643227797862, lat: 25.82133385975571 },
        { lng: 114.9613758810813, lat: 25.81834150683285 },
        { lng: 114.9581414800636, lat: 25.816454984607688 },
        { lng: 114.95318206516998, lat: 25.81499128286883 },
        { lng: 114.950630482145, lat: 25.813495035728792 },
        { lng: 114.94502418704789, lat: 25.80816043559642 },
        { lng: 114.93953141347649, lat: 25.80412817087722 },
        { lng: 114.93648047520966, lat: 25.807707561717777 },
        { lng: 114.94762118982572, lat: 25.816164775470398 },
        { lng: 114.93985862738357, lat: 25.82410099603871 },
        { lng: 114.94194301915044, lat: 25.826117491923867 },
        { lng: 114.94172739241593, lat: 25.839321438580683 },
        { lng: 114.93834924024202, lat: 25.839256398119232 },
        { lng: 114.92785540582945, lat: 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: {
    queryAddressSearch(queryString, cb) {
      var restaurants = [];
      if (this.restaurants) {
        restaurants.push({
          value: this.restaurants.address,
          point: this.restaurants.point,
        });
        this.restaurants.surroundingPois.forEach((item) => {
          restaurants.push({
            value: item.address + "-" + item.title,
            point: item.point,
          });
        });
      }
      let results = queryString
        ? restaurants.filter(this.createFilter(queryString))
        : restaurants;
      // 调用 callback 返回建议列表的数据
      cb(results);
    },
    createFilter(queryString) {
      return (restaurant) => {
        return (
          restaurant.value.toLowerCase().indexOf(queryString.toLowerCase()) ===
          0
        );
      };
    },
    handleAddressSelect(e) {
      this.form.address = e.value;
    },
    //输入关键词获取地址经纬度,在地图上标记 (橙色)
    searchcomplete(e) {
      if (e && e.Yr && e.Yr.length > 0) {
        const point = e.Yr[0].point;

        this.updateStoreMark(point);
      }
    },
    updateStoreMark(point) {
      this.center = point;
      const address = {
        ...point,
        icon: require("@/assets/shop.png"),
      };
       this.$message('lng:'+point.lng+",lat:"+point.lat);
      this.markers.splice(0, 1, address);
    },
    //点击地图新增标记或者移动标记位置  (红色)
    updateMarkerLocal(point, rs) {
      this.restaurants = rs;
      console.log(rs);
      this.form.address=rs.address
      this.addProblemAddressMark(point, false);
    },
    addProblemAddressMark(point, updateCenter = true) {
      const address = {
        ...point,
        dragging: true,
        icon: require("@/assets/address.png"),
        offset: [3, -18],
      };
      const len = this.markers.length || 0;
      if (len <= 1) {
        this.markers.push(address);
      } else {
        this.markers.splice(len - 1, 1, address);
      }
      
      if (updateCenter) {
        this.center = point;
      }
    },
  },
};
</script>
<style lang="scss" scoped>
.el-input,.el-autocomplete{
    width: 400px;
}
</style>

猜你喜欢

转载自blog.csdn.net/Holly31/article/details/130305461