欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue結(jié)合leaflet實(shí)現(xiàn)鷹眼圖

 更新時(shí)間:2023年06月26日 15:10:09   作者:努力搬磚的giser  
本文主要介紹了vue結(jié)合leaflet實(shí)現(xiàn)鷹眼圖,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

本文介紹了一個(gè)Web端使用Leaflet開發(fā)庫(kù)顯示鷹眼圖的方法 (底圖來(lái)源:天地圖),該插件可設(shè)置鷹眼小地圖的大小、位置、收縮展示狀態(tài)。

開發(fā)環(huán)境

Vue開發(fā)庫(kù):3.2.37 & Leaflet開發(fā)庫(kù):1.9.3

Leaflet插件:leaflet-minimap

使用教程

安裝依賴庫(kù)

方法一: 通過(guò)npm安裝依賴

npm i leaflet-minimap

方法二: 通過(guò)github倉(cāng)庫(kù)下載,引入項(xiàng)目中(推薦)

leaflet-minimap官網(wǎng) https://github.com/Norkart/Leaflet-MiniMap

克隆leaflet-minimap倉(cāng)庫(kù),下載完畢后,進(jìn)入Leaflet-MiniMap文件夾,將dist目錄下的文件夾引入本地項(xiàng)目中。為什么推薦該方式引入呢?是因?yàn)樵摬寮谶M(jìn)行最小化和展示時(shí),鼠標(biāo)懸浮 hover效果會(huì)有個(gè)英文提示出現(xiàn),本地引入可以將英文提示語(yǔ)修改為中文,而不用去修改node_modules中的文件。

git clone https://github.com/Norkart/Leaflet-MiniMap

使用簡(jiǎn)介

// 定義一個(gè)底圖(注意:小地圖的layer不能和地圖上共用一個(gè),否則無(wú)法加載)
const minilayer = L.tileLayer(`https://map.geoq.cn/ArcGIS/rest/services/ChinaOnlineStreetWarm/MapServer/tile/{z}/{y}/{x}`)
// 使用小地圖,添加到地圖上
const miniMap = new L.Control.MiniMap(minilayer, {
    // 鷹眼圖配置項(xiàng),參數(shù)非必須,可以忽略使用默認(rèn)配置
    width: 300, // 鷹眼圖寬度
    height: 200, // 鷹眼圖高度
    toggleDisplay: true, // 是否顯示最小化按鈕
    minimized: false, // 是否最小化位置開始
}).addTo(map);
// 改變鷹眼圖圖層源
// miniMap.changeLayer('新的layer');
// 移除鷹眼小地圖
// map.removeControl(miniMap);

以下是核心的參數(shù)配置項(xiàng),截圖于gitHub倉(cāng)庫(kù)(更新時(shí)間:2023年5月30日)

詳細(xì)源碼(Vue3)

<template>
  <div class="app-contain">
    <!-- leaflet 地圖容器 -->
    <div id="myMap"></div>
  </div>
</template>
<script setup>
// 引入樣式
import {onMounted} from 'vue'
// 引入leaflet
import L from 'leaflet';
import 'leaflet/dist/leaflet.css'
// 小地圖
import "./store/Control.MiniMap.min.js";
import "./store/Control.MiniMap.min.css";
// 天地圖TK
let tdtKey = 'YOURS_TK'
const initMap = () => {
  // 影像地圖
  const tiandituMap = L.tileLayer(`http://t0.tianditu.gov.cn/img_w/wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=img&STYLE=default&TILEMATRIXSET=w&FORMAT=tiles&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}&tk=${tdtKey}`)
  // 注記
  const tiandituText = L.tileLayer(`http://t0.tianditu.gov.cn/cia_w/wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=cia&STYLE=default&TILEMATRIXSET=w&FORMAT=tiles&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}&tk=${tdtKey}`)
  const layers = L.layerGroup([tiandituMap, tiandituText])
  let map = L.map('myMap', {  //需綁定地圖容器div的id
    center: [39.56, 116.20], //初始地圖中心
    zoom: 10, //初始縮放等級(jí)
    maxZoom: 18, //最大縮放等級(jí)
    minZoom: 0, //最小縮放等級(jí)
    zoomControl: true, //縮放組件
    attributionControl: false, //去掉右下角logol
    scrollWheelZoom: true, //默認(rèn)開啟鼠標(biāo)滾輪縮放
    // 限制顯示地理范圍
    maxBounds: L.latLngBounds(L.latLng(-90, -180), L.latLng(90, 180)),
    layers: [layers] // 圖層
  })
  /** 添加小地圖 */
  // 定義一個(gè)底圖(注意:小地圖的layer不能和地圖上共用一個(gè),否則無(wú)法加載)
  const minilayer = L.tileLayer(`https://map.geoq.cn/ArcGIS/rest/services/ChinaOnlineStreetWarm/MapServer/tile/{z}/{y}/{x}`)
  // 使用小地圖,添加到地圖上
  const miniMap = new L.Control.MiniMap(minilayer, {
    // 鷹眼圖配置項(xiàng),參數(shù)非必須,可以忽略使用默認(rèn)配置
    width: 300, // 鷹眼圖寬度
    height: 200, // 鷹眼圖高度
    toggleDisplay: true, // 是否顯示最小化按鈕
    minimized: false, // 是否最小化位置開始
  }).addTo(map);
  // miniMap.changeLayer('新的layer');
  // 移除小地圖
  // map.removeControl(miniMap);
}
onMounted(() => {
  initMap()
})
</script>
<style scoped>
#myMap {
  width: 86vw;
  height: 90vh;
}
</style>

 到此這篇關(guān)于vue結(jié)合leaflet實(shí)現(xiàn)鷹眼圖的文章就介紹到這了,更多相關(guān)vue leaflet鷹眼圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論