IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue-baidu-map -> 正文阅读

[JavaScript知识库]vue-baidu-map

先安装 npm install vue-bai-map --save
全局引用,找到main.js

import BaiduMap from 'vue-baidu-map'

Vue.use(BaiduMap, {
  // ak 是在百度地图开发者平台申请的密钥 详见 http://lbsyun.baidu.com/apiconsole/key */
  ak: '密钥'
})

最后就直接使用就好,例子如下:
后面样式是去掉了百度的logo以及标题

<template>
  <div class="app-container">
    <el-autocomplete
      v-model.trim="address"
      :fetch-suggestions="querySearch"
      placeholder="请输入详细地址"
      style="width: 40%"
      :trigger-on-focus="false"
      @select="handleSelect"
    />
    <div style="margin: 5px">
      <baidu-map
        class="map"
        ref="map"
        :center="mapCenter"
        :zoom="mapZoom"
        @click="paintPolyline"
        @ready="map_handler"
        @mousemove="mousemovePolyline"
        @rightclick="rightPolyline">
        <!--定位-->
        <bm-geolocation anchor="BMAP_ANCHOR_BOTTOM_RIGHT" :showAddressBar="true" :autoLocation="true"></bm-geolocation>
        <!--比例尺-->
        <bm-scale  anchor="BMAP_ANCHOR_BOTTOM_RIGHT"></bm-scale>
        <!--缩放-->
        <bm-navigation anchor="BMAP_ANCHOR_TOP_left"></bm-navigation>
        <!--地图右下角加入定位控件-->
        <bm-geolocation anchor="BMAP_ANCHOR_BOTTOM_RIGHT" :showAddressBar="true" :autoLocation="true"></bm-geolocation>
        <!--地图类型-->
        <bm-map-type :map-types="['BMAP_NORMAL_MAP', 'BMAP_HYBRID_MAP']" anchor="BMAP_ANCHOR_TOP_RIGHT"></bm-map-type>
        <bm-control style="padding-left: 50px">
          <button @click="toggle('polyline')">{{ polyline.editing ? '停止绘制' : '开始绘制' }}</button>
        </bm-control>
        <bm-polyline :path="path" v-for="path of polyline.paths" :key="path"></bm-polyline>
        <bm-polygon :path="polygonPath" stroke-color="blue" :stroke-opacity="0.5" :stroke-weight="2" :editing="true" @lineupdate="updatePolygonPath"/>
        <!--        <bm-marker :position="mapCenter" :dragging="true" animation="BMAP_ANIMATION_BOUNCE">-->
        <!--          <bm-label content="我爱北京天安门" :labelStyle="{color: 'red', fontSize : '24px'}" :offset="{width: -35, height: 30}"/>-->
        <!--        </bm-marker>-->
        <bm-local-search :keyword="address" :auto-viewport="true" style="display: none"></bm-local-search>
        <bml-drawing-manager :isOpen="true" :enableDrawingTool="enableDrawingTool">

        </bml-drawing-manager>
      </baidu-map>
    </div>
  </div>
</template>
<script>
  // 引入异步引入地图的方法
  //import { loadBaiDuDrawMap } from "@/util/bmpgl_lib.js";
  export default {
    name: "Map",
    data() {
      return {
        location: "湘潭市九华经开区", //百度地图默认优先检索地区
        keyword:  "", //百度地图搜索值
        coordinate: '', //
        polygonPath: [], // 多边形集合
        address: "", // 百度地图搜索框值
        mapZoom: 17, //百度地图展示层级
        mapCenter: { lng: 112.951737, lat: 27.929792 }, //lng: 百度地图经度  lat: 百度地图纬度
        selectFirstResult:true,//百度地图是否选择第一个检索结果
        pageCapacity:1,//百度地图设置每页容量,取值范围:1 - 100,对于多关键字检索,每页容量表示每个关键字返回结果的数量(例如当用2个关键字检索时,实际结果数量范围为:2 - 200)。此值只对下一次检索有效
        polyline: { // 折线的对象
          editing: false,
          paths: []
        },
        enableDrawingTool: '',
        drawingManager: '',
      };
    },
    methods:{
      map_handler({ BMap, map }) {
        this.BMap = BMap;
        this.map = map;
        if (this.coordinate && this.coordinate.lng) {
          this.mapCenter.lng = this.coordinate.lng
          this.mapCenter.lat = this.coordinate.lat
          this.mapZoom = 17
          var marker = new BMap.Marker(new BMap.Point(this.map.point.lng, this.map.point.lat));
          map.addOverlay(marker);
          //跳动的动画
          marker.setAnimation(BMAP_ANIMATION_BOUNCE);

        } else {
          this.mapCenter.lng = 112.951737
          this.mapCenter.lat = 27.929792
          this.mapZoom = 17
        }
      },

      // 搜索远程调用
      querySearch(queryString, cb) {
        var that = this;
        var myGeo = new this.BMap.Geocoder();
        myGeo.getPoint(
          queryString,
          function(point) {
            if (point) {
              that.coordinate = point;
              that.makerCenter(point);
            } else {
              that.coordinate = null;
            }
          },
          this.locationCity
        );
        var options = {
          onSearchComplete: function(results) {
            if (local.getStatus() === 0) {
              // 判断状态是否正确
              var s = [];
              for (var i = 0; i < results.getCurrentNumPois(); i++) {
                var x = results.getPoi(i);
                var item = { value: x.address + x.title, point: x.point };
                s.push(item);
                cb(s);
              }
            } else {
              cb();
            }
          },
        };
        var local = new this.BMap.LocalSearch(this.map, options);
        local.search(queryString);
      },
      // 点击 点击标注图标后会触发此事件
      paintPolyline(item) {
        var { point } = item;
        this.flag = true;
        this.makerCenter(point);
        if (!this.polyline.editing) {
          return
        }
        const {paths} = this.polyline
        !paths.length && paths.push([])
        paths[paths.length - 1].push(item.point)
      },
      // 搜索
      handleSelect(item) {
        var { point } = item;
        this.coordinate = point;
        this.makerCenter(point);
      },
      // 坐标添加
      makerCenter(point) {
        if (this.map) {
          this.map.clearOverlays();
          //var marker = new this.BMap.Marker(point);
          this.map.addOverlay(new this.BMap.Marker(point));
          //跳动的动画
          // eslint-disable-next-line no-undef
          //marker.setAnimation(BMAP_ANIMATION_BOUNCE);
          this.mapCenter.lng = point.lng;
          this.mapCenter.lat = point.lat;
          this.mapZoom = 17;
          this.mapCenter= { lng: point.lng, lat: point.lat }
        }
      },
      // 按钮控制 是否启用线编辑
      toggle (name) {
        this[name].editing = !this[name].editing
      },
      // 鼠标移除的时候   当鼠标进入折线区域时会触发此事件
      mousemovePolyline (e) {
        if (!this.polyline.editing) {
          return
        }
        const {paths} = this.polyline
        if (!paths.length) {
          return
        }
        const path = paths[paths.length - 1]
        if (!path.length) {
          return
        }
        if (path.length === 1) {
          path.push(e.point)
        }
        this.$set(path, path.length - 1, e.point)
        //console.log(12,e.point)
      },
      // 鼠标右击结束划区域 右键单击地图时触发此事件
      rightPolyline () {
        if (!this.polyline.editing) {
          return
        }
        const {paths} = this.polyline
        if(!paths.length) {
          paths.push([])
        }
        const path = paths[paths.length - 1]

        path.pop()
        if (path.length) {
          paths.push([])
          this.map.clearOverlays(); // 去除覆盖物
          this.polygonPath = path
        }
      },
      // 多边形的更新  覆盖物的属性发生变化时触发
      updatePolygonPath(e) {
        this.polygonPath = e.target.getPath()
      },
    }
  };
</script>
<style scoped>
  .rowMap {
    margin-bottom: 15px;
  }
  .map{
    height: 500px;
  }
  >>>.anchorBL,

    /*>>>.anchorTR,去除二维或三维的*/

  >>>.BMap_zlHolder{

    display:none;

    visibility:hidden;

  }
</style>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-22 20:27:56  更:2022-03-22 20:30:17 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:20:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码