vue-baidu-map离线地图配置详解

最近有一个项目需要用到地图来展示位置并进行数据交互,用vue-baidu-map实现出来后,又告诉我他们没有外网,查了各种资料文档,觉得方法很麻烦,在vue-baidu-map测试还会有很多问题,于是又开始漫长的找源码,不停测试,找到了可以在没外网的环境下离线使用组件查看地图的方式。
(更新于2021-04-23)


很久没有更新,发现近期有小伙伴出现一些问题,这里自己又试了一下,测试没问题,所以稍加补充了内容(更新于2022-05-12)


前期,首先安装vue-baidu-map,并在main.js调用组件:

import BaiduMap from 'vue-baidu-map'
Vue.use(BaiduMap, {
  ak: '你的百度地图秘钥AK' //离线环境可不填
})

1.下载百度api的js代码

访问地址,(注意地址参数,我这里使用的是2.0版本,每个版本代码有不同,按后面的操作修改对应代码就好)

http://api.map.baidu.com/getscript?v=2.0&ak= 你的百度地图ak密钥

打开后看到堆压缩代码,复制代码,找一个工具格式化为容易编辑的代码格式;
工具地址:http://www.bejson.com/
格式化后全部复制,另存为js文件到本地,比如baidu-api.js,用nginx代理;
测试访问代理地址,比如 http://127.0.0.1:9800/baidu-api.js ,看是否能查看到此文件内容

2.创建并引入baidu-init.js文件

添加一个js文件,和baidu-api.js保存在同一文件夹,可以将文件命名为baidu-init.js,代码如下:

(function(){window.HOST_TYPE = "2"; window.BMap_loadScriptTime = (new Date).getTime(); window.BMap=window.BMap||{};window.BMap.apiLoad=function(){delete window.BMap.apiLoad;if(typeof _initBaiduMap=="function"){_initBaiduMap()}};var s=document.createElement('script');s.src='http://127.0.0.1:9800/baidu-api.js';document.body.appendChild(s);})();

测试访问代理地址,比如 http://127.0.0.1:9800/baidu-init.js ,看是否能查看到此文件内容

修改baidu-init.js文件, 替换成baidu-api.js的代理地址

s.src='http://127.0.0.1:9800/baidu-api.js';document.body.appendChild(s);})();

在vue依赖包 node_modules文件找到,vue-baidu-map

在这里插入图片描述
找到根目录的 index.js文件,可以看到是压缩的js代码,查找 https://api.map.baidu.com/api?v
在这里插入图片描述

将地址全部替换为你代理本地文件baidu-init.js的地址,如:

http://127.0.0.1:9080/baidu-init.js

3.下载百度地图瓦片

网上下载资源和资料很多,都可以试一下能不能下载,最好下载到16、17级试一下,17、18、19级瓦片会很大,下载过程比较慢。
在这里插入图片描述
下载好以后,同样将瓦片资源代理到本地。
然后测试,比如我代理的地址为:
在这里插入图片描述
按照上图下载的文件,测试 http://127.0.0.1:9900/13/1546/310.png 看是否能访问本地图片;

4.修改baidu-api.js

用url.domain.main_domain_cdn多找几次,定位到代码:
在这里插入图片描述
按图片中修改,B.JN=“”

用&callback=BMap.多找几次,定位到代码:在这里插入图片描述
第一行添加代码:if (/^http/.test(a)) return;

用 url.domain.main_domain_cdn多找几次,定位到下面代码:
我修改后的代码(注意有些变量不同):
可以打印一下变量看看代表的是目录的哪一级,修改自己代理的瓦片资源路径;
替换return值: return “http://127.0.0.1:9700/” + d + “/” + e + “/” + k + “.png”

修改:

在这里插入图片描述
同理,换成自己代理的瓦片地址。
注意红色圈起来的位置,为拼接路径;

最后根据自己的需求按照vue-baidu-map的官方文档正常编写就可以了!!
断开网络试试吧!!

demo实例:

<template>
  <el-row :gutter="15">
    <el-col :span="18">
      <div class="map marginBottom" style="border-radius: 4px;overflow: hidden;">
        <!-- 给地图加点击事件getLocationPoint,点击地图获取位置相关的信息,经纬度啥的 -->
        <!-- scroll-wheel-zoom:是否可以用鼠标滚轮控制地图缩放,zoom是视图比例 -->
        <baidu-map :mapStyle="mapStyle" :mapClick="false" :scroll-wheel-zoom="false" :center="center" :zoom="zoom" @click="getLocationPoint">
          <bm-view style="width: 100%; height:600px; flex: 1"></bm-view>
          <bm-local-search :keyword="addressKeyword" :auto-viewport="true" style="display: none"></bm-local-search>
          <map-overlay :position="{lng: 114.075673,lat: 22.521582}" text="福田口岸" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.072825,lat: 22.529861}" text="福民" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.074473, lat: 22.540912}" text="岗厦" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.07425, lat: 22.555351}" text="莲花村" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.074174, lat: 22.565942}" text="冬瓜岭" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.074156, lat: 22.574152}" text="孖岭" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.066938, lat: 22.609605}" text="雅宝" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.067005, lat: 22.616831}" text="南坑" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.067396, lat: 22.622319}" text="光雅园" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.067286, lat: 22.632149}" text="五和" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.069952, lat: 22.640902}" text="坂田北" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.072948, lat: 22.647426}" text="贝尔路" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.073885, lat: 22.656419}" text="华为" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.078323, lat: 22.663063}" text="岗头" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.086368, lat: 22.662458}" text="雪象" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.112471, lat: 22.654079}" text="甘坑" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.125145, lat: 22.653388}" text="凉帽山" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.133661, lat: 22.660692}" text="上李朗" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.128775, lat: 22.676866}" text="木古" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.128631, lat: 22.683068}" text="华南城" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.127484, lat: 22.692649}" text="禾花" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.132394, lat: 22.700272}" text="平湖" @changeZoom="changeZoom"></map-overlay>
          <map-overlay :position="{lng: 114.139279, lat: 22.705197}" text="双拥街" @changeZoom="changeZoom"></map-overlay>
          <bm-polyline :path="path" v-for="path of polyline.paths"></bm-polyline>
          <bm-control>
            <el-button style="margin-top: 10px;margin-left: 10px;" @click="changeZoom(13,{lng: 114.143455, lat: 22.609943})" size="mini" icon="el-icon-c-scale-to-original">还原</el-button>
          </bm-control>
        </baidu-map>
      </div>
</template>

<script>
  import MapOverlay from "@/components/MapOverlay"
  export default {
    components:{MapOverlay},
    data(){
      return {
        addressKeyword:"",
        center: {lng: 114.143455, lat: 22.609943},
        zoom: 13,
        text:"",
        mapType:"BMAP_NORMAL_MAP",
        mapStyle:{
          styleJson:[
            {"featureType": "land", "elementType": "all", "stylers": {"color": "#111424ff" }},
            {"featureType": "road", "elementType": "all", "stylers": {"color": "#293142ff"}},
            {"featureType": "water", "elementType": "all", "stylers": { "color": "#1b2638ff" }},
            {"featureType": "green", "elementType": "all", "stylers": { "color": "#111424ff"}},
            {"featureType": "manmade", "elementType": "all", "stylers": { "color": "#111424ff" }},
            {"featureType": "building", "elementType": "all", "stylers": {"color": "#f1c232ff"}},
            {"featureType": "all", "elementType": "labels", "stylers": { "visibility": "off"}}
          ]
        },
        polyline: {
          paths:[
            [
              {lng: 114.075673,lat: 22.521582},
              {lng: 114.072825,lat: 22.529861},
              {lng: 114.074473, lat: 22.540912},
              {lng: 114.07425, lat: 22.555351},
              {lng: 114.074174, lat: 22.565942},
              {lng: 114.074156, lat: 22.574152},
              {lng: 114.066938, lat: 22.609605},
              {lng: 114.067005, lat: 22.616831},
              {lng: 114.067396, lat: 22.622319},
              {lng: 114.067286, lat: 22.632149},
              {lng: 114.069952, lat: 22.640902},
              {lng: 114.072948, lat: 22.647426},
              {lng: 114.073885, lat: 22.656419},
              {lng: 114.078323, lat: 22.663063},
              {lng: 114.086368, lat: 22.662458},
              {lng: 114.112471, lat: 22.654079},
              {lng: 114.125145, lat: 22.653388},
              {lng: 114.133661, lat: 22.660692},
              {lng: 114.128775, lat: 22.676866},
              {lng: 114.128631, lat: 22.683068},
              {lng: 114.127484, lat: 22.692649},
              {lng: 114.132394, lat: 22.700272},
              {lng: 114.139279, lat: 22.705197},
            ],
            []
          ]
        },
      }
    },
    created(){
      
    },
    methods: {
      
    }
  }
</script>


在这里插入图片描述
在这里插入图片描述

拖动或缩放会自动加载本地资源瓦片,如果下载的瓦片不全,就会出现上图的白板情况,根据自己的需要下载相应的区域瓦片即可。

  • 10
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 38
    评论
### 回答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离线百度地图为开发者提供了便捷灵活的地图开发工具,让用户可以更加自由地使用地图服务。
评论 38
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值