vue-百度地图

由于公司需求,需要引用百度地图来确定配送范围(覆盖物),本人不是专业前端,只做一个简单分享,可能不是很清晰,有高见望指教。

公司前端是用vue写的,所以百度地图需要先引入百度地图vue的插件

第一步:下载vue百度地图插件

获取地址:链接:百度网盘 请输入提取码

提取码:1212

第二步:页面引入:

import BaiduMap from 'vue-baidu-map/components/map/Map.vue';
export default {
  components: {
    BaiduMap,
  },

第三步:创建地图实例

<div class="map">
  <el-input v-model="addressKeyword" placeholder="请输入地址来直接查找相关位置"></el-input>
  <!-- 给地图加点击事件getLocationPoint,点击地图获取位置相关的信息,经纬度啥的 -->
  <!-- scroll-wheel-zoom:是否可以用鼠标滚轮控制地图缩放,zoom是视图比例 
  center中心点 map-click:点击地图是否显示标志物-->
  <baidu-map  v-if="open2"
              :center="pointBak"
             :zoom="14"
             :map-click="false"
             :scroll-wheel-zoom="true"
              @click="paintPolygon"
             @ready="mapReady"
             style="width: 400px;height: 400px;border: #1c84c6">
    <bm-marker :position="this.pointBak" :dragging="true" @dragend="dragend" >
    </bm-marker>
    <bm-control>
      <button @click="toggle('polygonPath')">{{ polygonPath.editing ? '停止绘制' : '开始绘制' }}</button>
    </bm-control>
    <bm-local-search :keyword="addressKeyword" :auto-viewport="true" style="display: none"></bm-local-search>
  </baidu-map>
</div>

第四步:data中添加属性

baiduMap:undefined,
polygon:undefined,
path: [],
polygonPath: {
  editing: false,
  paths: [] // 绘制完成后的经纬度,其实是在画的时候动态push的,因为在点击的时候触发了 paintPolygon 函数
},
pointBak:{},
addressKeyword:'',

第五步:编写方法

  /*百度地图*/
  //控制绘制地图开关
  toggle (name) {
    if(!this.polygon){
      this.addCovering();
    }
    if(this[name].editing){
      this.polygon.disableEditing();
    }else {
      this.polygon.enableEditing();
    }
        this[name].editing = !this[name].editing
        // 在这里做一步判断,如果有路径且开启绘制就把原来的路径清空
        if (this.path && this.polygonPath.editing) {
            this.path = []
          }
      },
  // 鼠标右键多边形绘制完成
  paintPolygon (e) {
    if (!this.polygonPath.editing) {
      return
    }
    this.path = this.polygon.getPath();
    this.path.push(e.point);
    this.polygon.setPath(this.path);
  },
  // 当编辑时触发 动态添加点
    updatePolygonPath (e) {
    console.log(e.target.getPath(),'eee',this.polygonPath.paths[0])
  },
 //获取当前位置,如果用户同意获取
  mapReady({BMap,map}){
    let geoLocation = new BMap.Geolocation();
    this.baiduMap = map;
    if(this.formCustom.id == null){
      geoLocation.getCurrentPosition((geolocationResult)=>{
        if(geolocationResult.point == null){
          this.pointBak = {lat:26.65332482,lng:106.63657676};
        }else{
          this.pointBak = geolocationResult.point;
        }
      });
    }else{
      this.pointBak = {lng:this.formCustom.lng,lat:this.formCustom.lat};
    }
    this.addCovering();
  },
  //添加覆盖物
  addCovering(){
//创建覆盖物实例polygon
    this.polygon = new BMap.Polygon();
    this.polygon.setStrokeColor("#999093");
    this.polygon.setFillColor("#20B2AA");
    this.polygon.setStrokeWeight(3);
    this.polygon.getFillOpacity(0.3);
    this.polygon.setStrokeStyle("dashed");
    let arrPath = [];
    if(this.path){
      this.path.forEach(item =>{
        arrPath.push(new BMap.Point(item.lng,item.lat));
      })
    }
    //set经纬度到地图
    this.polygon.setPath(arrPath);
    this.baiduMap.addOverlay(this.polygon);
  },
  /** 根据地址获取经纬度,这里是我有一个选择省市县的框,选择自动调整地图位置*/
  addCoutomMarkerProvince(point){
    this.pointBak = point;
    this.baiduMap.addOverlay(new BMap.Marker(point));
},addCoutomMarkerCity(point){
    this.pointBak = point;
    this.baiduMap.addOverlay(new BMap.Marker(point));
},addCoutomMarkerCounty(point){
    this.pointBak = point;
    this.baiduMap.addOverlay(new BMap.Marker(point));
},
  // 点击移动中心点 动态获取point
  dragend(e){
    this.pointBak = e.point;
  },

最终效果:

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: vue-baidu-map是基于百度地图API开发的Vue组件,它能够在Vue项目中轻松地集成百度地图。而离线百度地图是指在没有网络连接的情况下能够使用的百度地图。 正常情况下,百度地图需要联网才能显示地图和获取相关数据。但是在有些场景下,比如地下车库或者偏远山区等网络较差或者没有网络的地方,就无法正常使用百度地图。离线百度地图就是解决这个问题的解决方案,它通过事先将地图数据下载保存在本地,使得在没有网络连接的情况下也能够正常使用百度地图。 对于vue-baidu-map来说,它的离线功能也是很重要的。通过使用vue-baidu-map的离线百度地图,开发者可以轻松地针对不同的场景选择不同的地图方案,提高用户的使用体验。而且离线百度地图对于一些隐私性、安全性要求高的应用场景也更加有优势。 总之,vue-baidu-map离线百度地图是一个非常实用与方便的工具,在实际生产中可以提供更好的用户体验,也为开发者提供了更多的选择与便捷。 ### 回答2: vue-baidu-map离线百度地图是一款基于Vue.js框架开发的百度地图组件库,主要解决的是在无网络或网络不稳定的情况下,无法使用在线地图的问题。该组件库提供的离线地图可以在无网络的情况下正常使用,并且具有与在线地图相同的功能和可视化效果。 在vue-baidu-map离线百度地图组件中,我们可以使用百度地图提供的基础地图、卫星地图、混合地图等多种地图样式,并且支持地名搜索、地图缩放、位置探测、路线规划等常用功能。此外,在使用vue-baidu-map离线百度地图时,我们也可以通过添加自定义数据层、自定义覆盖层等方式,对地图进行更加丰富的扩展和定制。 总之,vue-baidu-map离线百度地图是一款非常实用的地图组件库,它可以帮助我们在网络不稳定或者无网络的情况下,依然可以正常使用百度地图,并且具有完整的百度地图功能和美观的地图样式。如果你正在建设一个应用程序,需要集成离线地图功能,那么vue-baidu-map离线百度地图可能正是你需要的工具。 ### 回答3: vue-baidu-map是一个可嵌入Vue.js网站的地图组件,它集成了百度地图的API,可以让开发者轻松实现地图功能。 离线百度地图指的是一种不需要联网即可使用的百度地图,也就是地图数据被下载到本地储存设备上。vue-baidu-map支持使用离线地图,这就意味着用户可以在没有网络的环境下依然能够使用地图功能。 使用vue-baidu-map离线百度地图的优势在于,它提供了更好的用户体验和更高的灵活性。首先,用户无需担心网络不稳定、信号弱的问题,可以随时随地使用地图进行定位、浏览、搜索等操作;其次,开发者可以根据具体需求选择下载特定区域的地图数据,以减少数据流量和缩短加载时间;还可以根据不同需求切换在线地图和离线地图,达到最佳的用户体验。 总之,vue-baidu-map离线百度地图为开发者提供了便捷灵活的地图开发工具,让用户可以更加自由地使用地图服务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值