Vue中百度地图(vue-baidu-map)的使用

1、开始

vue-map-baidu:https://dafrok.github.io/vue-baidu-map/#/zh/start/installation
百度地图开发者平台申请密钥详见: http://lbsyun.baidu.com/apiconsole/key */

2、bm-marker和bm-info-window实现定位和定位详情弹窗功能

拾取坐标系统详见:http://api.map.baidu.com/lbsapi/getpoint/index.html

<template>
  <baidu-map
      class="bm-view"
      :center="{lng: 116.383141, lat: 39.913607}"
      zoom="12"
      :scroll-wheel-zoom="true">

    <bm-marker
        v-for="(marker,index) of markers"
        :key="index"
        :position="{lng: marker.lng, lat: marker.lat}"
        @click="lookDetail(marker)"
        :icon="{url: 'http://api0.map.bdimg.com/images/marker_red_sprite.png', size: {width: 100, height: 100}}"
        >

     <bm-info-window
          :title="infoWindow.name"
          :position="{lng: infoWindow.lng, lat: infoWindow.lat}"
          :show="marker.showFlag"
          @close="infoWindowClose(marker)">
      </bm-info-window>
    </bm-marker>


    <!--比例尺控件-->
    <bm-scale anchor="BMAP_ANCHOR_TOP_RIGHT"></bm-scale>
    <!--缩放控件-->
    <bm-navigation anchor="BMAP_ANCHOR_BOTTOM_RIGHT"></bm-navigation>
  </baidu-map>
</template>

<script>
import BaiduMap from 'vue-baidu-map/components/map/Map.vue'
import BmScale from 'vue-baidu-map/components/controls/Scale'
import BmNavigation from 'vue-baidu-map/components/controls/Navigation'
import BmMarker from 'vue-baidu-map/components/overlays/Marker'
import BmInfoWindow from 'vue-baidu-map/components/overlays/InfoWindow'

export default {
  name: "Atlas",

  components:{
    BaiduMap,
    BmScale,
    BmNavigation,
    BmMarker,
    BmInfoWindow,
  },

  data(){
    return{
      // 地图标记点
      markers:[
        {
          lng: '116.383141',
          lat: '39.913607',
          name: '信息窗口1',
          showFlag:false
        },

        {
          lng: '116.383141',
          lat: '39.900000',
          name: '信息窗口2',
          showFlag:false
        },
      ],
      infoWindow:{},

      mapStyle: {
        styleJson: [
          {
            "featureType": "all",
            "elementType": "geometry",
            "stylers": {
              "hue": "#007fff",
              "saturation": 89
            }
          },
          {
            "featureType": "water",
            "elementType": "all",
            "stylers": {
              "color": "#ffffff"
            }
          }
        ]
      }
    }
  },

  methods:{
    // 点击点坐标赋值
    lookDetail(marker){
      marker.showFlag = true;
      this.infoWindow = marker;
    },

    // 关闭弹窗
    infoWindowClose(marker) {
      marker.showFlag = false
    },

  }
}
</script>

<style scoped>
.bm-view{
  width: 100%;
  height: 87vh;
}
</style>

其中markers可以是使用vue中的axios从后端获取的坐标信息,也可以是使用vue中的axios从data.json中获取的坐标信息

3、效果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值