中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue項目中怎么使用mapbox地圖切換底圖

發布時間:2023-04-27 11:28:32 來源:億速云 閱讀:129 作者:iii 欄目:開發技術

這篇文章主要介紹了vue項目中怎么使用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地圖默認國外,可以使用天地圖的地圖來換底圖

另外可以實現地圖切換功能

vue項目中怎么使用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地圖切換底圖”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

镇康县| 嘉荫县| 浪卡子县| 宁强县| 石渠县| 大新县| 福安市| 岳普湖县| 铜陵市| 富平县| 张北县| 天等县| 久治县| 集贤县| 安庆市| 泸溪县| 舞阳县| 南部县| 离岛区| 肥东县| 徐州市| 遵化市| 元朗区| 渝北区| 临武县| 象山县| 和平区| 柞水县| 邓州市| 横峰县| 高清| 稻城县| 凌海市| 江川县| 徐州市| 百色市| 海兴县| 讷河市| 禹城市| 吴旗县| 阿图什市|