vue项目中使用mapbox地图切换底图的详细教程

 更新时间:2023年04月27日 10:48:19   作者:哪有人敲代码不戴头盔的  
最近开始入坑前端mapbox地图,跟大家一起慢慢深入学习,下面这篇文章主要给大家介绍了关于vue项目中使用mapbox地图切换底图的详细教程,文中给出了详细的实例代码,需要的朋友可以参考下

如何在vue项目中加载并使用mapbox

mapbox用了感觉确实不错,操作很顺滑,矢量切片体验流畅,地图主题定制化地图漂亮,二三维一体化,二三维切换很是简单,一行代码搞定。

基本使用

这是mapbox官方文档地址:mapbox文档

里面有很多官方例子,基本就是copy下来就能用。

开始使用

首先安装mapbox依赖

npm install --save mapbox-gl

然后引入css文件,css引入方法很多,可以在style中import,也可以在入口文件public的index.html中引入,下面是index.html引入

<!--mapbox  -->
<script src='https://api.mapbox.com/mapbox-gl-js/v2.11.0/mapbox-gl.js'></script>
<link href='https://api.mapbox.com/mapbox-gl-js/v2.11.0/mapbox-gl.css' rel='stylesheet' />

手动导入mapboxgl对象

import mapboxgl from 'mapbox-gl'

初始化

mapboxgl.accessToken = 'YOUR_MAPBOX_ACCESS_TOKEN';
  	const map = new mapboxgl.Map({
	container: 'map', // 地图容器
// Choose from Mapbox's core styles, or make your own style with Mapbox Studio
	style: 'mapbox://styles/mapbox/streets-v12', // style URL
	center: [-74.5, 40], // starting position [lng, lat]
	zoom: 9 // starting zoom
});

一个基本maobox地图就出来了

底图切换

mapbox地图默认国外,可以使用天地图的地图来换底图

另外可以实现地图切换功能

实现思路就是把所有的图层先加上,通过mapbox方法控制显隐,比较方便,可以控制图层的显示层级

data() {
    return {
      tk: '自己的天地图token',
      tk2: '自己的天地图token',
      // 影像
      yxBaseUrl:
        'https://t' + Math.floor(Math.random() * 7) + '.tianditu.gov.cn/DataServer?T=img_w&X={x}&Y={y}&L={z}&tk=',
      yxBaseCav:
        'https://t' + Math.floor(Math.random() * 7) + '.tianditu.gov.cn/DataServer?T=cia_w&X={x}&Y={y}&L={z}&tk=',
      // 电子
      dzBaseUrl:
        'https://t' + Math.floor(Math.random() * 7) + '.tianditu.gov.cn/DataServer?T=vec_w&X={x}&Y={y}&L={z}&tk=',
      dzBaseCav:
        'https://t' + Math.floor(Math.random() * 7) + '.tianditu.gov.cn/DataServer?T=cva_w&X={x}&Y={y}&L={z}&tk=',
      // 地形
      dxBaseUrl:
        'https://t' + Math.floor(Math.random() * 7) + '.tianditu.gov.cn/DataServer?T=ter_w&X={x}&Y={y}&L={z}&tk=',
      dxBaseCav:
        'https://t' + Math.floor(Math.random() * 7) + '.tianditu.gov.cn/DataServer?T=cta_w&X={x}&Y={y}&L={z}&tk=',
    }
  },

这是三种底图。

地图初始化加载,并把三种底图加上

createViewer(callback) {
      var yxBaseUrl = {
        //类型为栅格瓦片
        type: 'raster',
        tiles: [this.yxBaseUrl + this.tk],
        tileSize: 256,
      }
      var yxBaseCav = {
        type: 'raster',
        tiles: [this.yxBaseCav + this.tk2],
        tileSize: 256,
      }
      // 电子底图
      var dzBaseUrl = {
        //类型为栅格瓦片
        type: 'raster',
        tiles: [this.dzBaseUrl + this.tk],
        tileSize: 256,
      }
      var dzBaseCav = {
        type: 'raster',
        tiles: [this.dzBaseCav + this.tk2],
        tileSize: 256,
      }
      // 地形底图
      var dxBaseUrl = {
        //类型为栅格瓦片
        type: 'raster',
        tiles: [this.dxBaseUrl + this.tk],
        tileSize: 256,
      }
      var dxBaseCav = {
        type: 'raster',
        tiles: [this.dxBaseCav + this.tk2],
        tileSize: 256,
      }
      mapboxgl.accessToken = '自己的mapboxToken'
      let viewer = new mapboxgl.Map({
        container: this.mapId, // container ID
        style: 'mapbox://styles/mapbox/streets-v12', // style URL
        center: [108.06590205, 41.17608996], // starting position [lng, lat]
        zoom: 4, // starting zoom
        style: {
          //地图雾效果,主要在三维展示
          fog: {
            range: [2, 20],
            color: 'hsl(0, 0%, 100%)',
            'high-color': 'hsl(210, 100%, 80%)',
            'space-color': [
              'interpolate',
              ['exponential', 1.2],
              ['zoom'],
              5,
              'hsl(210, 40%, 30%)',
              7,
              'hsl(210, 100%, 80%)',
            ],
            'horizon-blend': ['interpolate', ['exponential', 1.2], ['zoom'], 5, 0.02, 7, 0.08],
            'star-intensity': ['interpolate', ['exponential', 1.2], ['zoom'], 5, 0.1, 7, 0],
          },
          //设置版本号,一定要设置
          version: 8,
          projection: {
            name: 'globe',
          },
          //添加来源
          sources: {
            yxBaseUrl: yxBaseUrl,
            yxBaseCav: yxBaseCav,
            dzBaseUrl: dzBaseUrl,
            dzBaseCav: dzBaseCav,
            dxBaseUrl: dxBaseUrl,
            dxBaseCav: dxBaseCav,
          },
          layers: [
            {
              //图层id,要保证唯一性
              id: 'yxBaseUrl',
              //图层类型
              type: 'raster',
              //数据源
              source: 'yxBaseUrl',
              layout: {
                visibility: 'visible',
              },
              //图层最小缩放级数
              minzoom: 0,
              //图层最大缩放级数
              maxzoom: 17,
            },
            {
              id: 'yxBaseCav',
              type: 'raster',
              source: 'yxBaseCav',
              layout: {
                visibility: 'visible',
              },
              minzoom: 0,
              maxzoom: 17,
            },
            {
              //图层id,要保证唯一性
              id: 'dzBaseUrl',
              //图层类型
              type: 'raster',
              //数据源
              source: 'dzBaseUrl',
              layout: {
                visibility: 'none',
              },
              //图层最小缩放级数
              minzoom: 0,
              //图层最大缩放级数
              maxzoom: 17,
            },
            {
              id: 'dzBaseCav',
              type: 'raster',
              layout: {
                visibility: 'none',
              },
              source: 'dzBaseCav',
              minzoom: 0,
              maxzoom: 17,
            },
            {
              //图层id,要保证唯一性
              id: 'dxBaseUrl',
              //图层类型
              type: 'raster',
              layout: {
                visibility: 'none',
              },
              //数据源
              source: 'dxBaseUrl',
              //图层最小缩放级数
              minzoom: 0,
              //图层最大缩放级数
              maxzoom: 17,
            },
            {
              id: 'dxBaseCav',
              type: 'raster',
              layout: {
                visibility: 'none',
              },
              source: 'dxBaseCav',
              minzoom: 0,
              maxzoom: 17,
            },
          ],
        },
      })
      callback(viewer)
    },

这是底图切换的方法

<template>
  <div class="toolsbar-mappic">
    <ul id="basemaps" v-for="(item, i) in baseMapList" :key="i">
      <li :class="item.visible ? 'hover' : ''" @click="changeBaseMaps(item, i)">
        <a>
          <div><img :src="item.iconUrl" /></div>
          <div>{{ item.name }}</div>
        </a>
      </li>
    </ul>
  </div>
</template>
<script>
import global from '@comp/Global.vue'
export default {
  data() {
    return {
      baseMapList: [
        {
          visible: true,
          name: '影像',
          id:'yxBaseUrl',
          iconUrl: 'img/basemap/img.png',
        },
        {
          visible: false,
          name: '电子',
          id:'dzBaseUrl',
          iconUrl: 'img/basemap/elec.png',
        },
        {
          name: '地形',
          visible: false,
          id:'dxBaseUrl',
          iconUrl: 'img/basemap/ter.png',
        },
      ],
    }
  },
  mounted() {
  },
  methods: {
    changeBaseMaps(item, index) {
    //global.map3d是mapbox地图的全局对象
      let styleJson = global.map3d.getStyle();
      styleJson.layers.forEach((item)=>{
        if(item.layout&&item.layout.visibility){
          global.map3d.setLayoutProperty(item.id, 'visibility', 'none')
        }
      })
      global.map3d.setLayoutProperty(item.id, 'visibility', 'visible')
      this.baseMapList.forEach((val, index, arr) => {
        val['visible'] = false
      })
      item['visible'] = true
    },
  },
}
</script>

总结

到此这篇关于vue项目中使用mapbox地图切换底图的文章就介绍到这了,更多相关vue使用mapbox地图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue3容器布局和导航路由实现示例

    vue3容器布局和导航路由实现示例

    这篇文章主要为大家介绍了vue3容器布局和导航路由实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • vue3 el-upload单张图片回显、编辑、删除功能实现

    vue3 el-upload单张图片回显、编辑、删除功能实现

    这篇文章主要介绍了vue3 el-upload单张图片回显、编辑、删除功能实现,图片回显时隐藏上传区域,鼠标悬浮显示遮罩层进行编辑、删除操作,删除图片后显示上传区域,本文通过实例代码分享实现方法,感兴趣的朋友一起看看吧
    2023-12-12
  • vue使用$emit实现同步调用

    vue使用$emit实现同步调用

    这篇文章主要介绍了vue使用$emit实现同步调用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • Vue.js 中的 $watch使用方法

    Vue.js 中的 $watch使用方法

    本篇文章中主要介绍了Vue.js 中的 $watch使用方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 详细聊聊Vue的混入和继承

    详细聊聊Vue的混入和继承

    混入(mixin)是一种非常灵活的方式,用来分发Vue组件中可复用的功能,一个混入对象可以包含任意组件选项,下面这篇文章主要给大家介绍了关于Vue混入和继承的相关资料,需要的朋友可以参考下
    2021-09-09
  • elementui源码学习仿写el-collapse示例

    elementui源码学习仿写el-collapse示例

    这篇文章主要为大家介绍了elementui源码学习之仿写el-collapse示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Vue中xlsx的使用方法指南

    Vue中xlsx的使用方法指南

    这篇文章主要给大家介绍了关于Vue中xlsx的使用方法指南,有很多办法都可以实现,其中最简单的还是使用插件xlsx,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • 一文详解Vue3中如何使用Vue Router

    一文详解Vue3中如何使用Vue Router

    Vue-Router路由是根据不同的url地址展现不同的内容或页面,这篇文章主要给大家介绍了关于Vue3中如何使用Vue Router的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-02-02
  • 使用vue.js 为基础的仿QQ聊天室

    使用vue.js 为基础的仿QQ聊天室

    这篇文章主要为大家介绍了基于vue.js的QQ聊天室,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-12-12
  • vue.js引入外部CSS样式和外部JS文件的方法

    vue.js引入外部CSS样式和外部JS文件的方法

    这篇文章主要介绍了vue.js引入外部CSS样式和外部JS文件的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01

最新评论