vue結(jié)合leaflet實(shí)現(xiàn)地圖放大鏡
本文介紹了Web端使用 Leaflet開(kāi)發(fā)庫(kù)顯示地圖放大鏡的方法 (底圖來(lái)源:中科星圖),結(jié)合 leaflet.magnifyingglass插件可以為L(zhǎng)eaflet圖層添加“放大鏡”效果,能夠以不同的縮放比例顯示地圖的一部分 ,顯示效果如下圖所示。

開(kāi)發(fā)環(huán)境
Vue開(kāi)發(fā)庫(kù):3.2.37 & Leaflet開(kāi)發(fā)庫(kù):1.9.3
Leaflet插件:leaflet.magnifyingglass
使用教程
安裝依賴庫(kù)
通過(guò)github倉(cāng)庫(kù)下載,引入項(xiàng)目中
leaflet.magnifyingglass倉(cāng)庫(kù) https://github.com/bbecquet/Leaflet.MagnifyingGlass
克隆leaflet.magnifyingglass倉(cāng)庫(kù),下載完畢后,進(jìn)入Leaflet.MagnifyingGlass文件夾,將該目錄下的leaflet.magnifyingglass.js和leaflet.magnifyingglass.css引入本地項(xiàng)目中。
# 克隆leaflet.magnifyingglass倉(cāng)庫(kù) git clone https://github.com/bbecquet/Leaflet.MagnifyingGlass.git

使用簡(jiǎn)介
// 創(chuàng)建地圖放大鏡底圖(請(qǐng)勿使用主地圖已在使用的圖層對(duì)象)
const baseLayer1 = L.tileLayer('https://tiles1.geovisearth.com/base/v1/vec/{z}/{x}/{y}?token=yours_token');
const vecLayer = L.layerGroup([baseLayer1])
// 創(chuàng)建地圖放大鏡圖層,并添加到地圖中
let magnifyingGlass = L.magnifyingGlass({
// 主地圖縮放和放大鏡之間的縮放級(jí)別偏移
zoomOffset: 3,
layers: [vecLayer]
}).addTo(map);以下是核心的參數(shù)配置項(xiàng)(更新時(shí)間:2023年5月13日)
| 參數(shù) | 類型 | 默認(rèn) | 描述 |
|---|---|---|---|
| radius | Integer | 100 | 放大鏡的半徑(以像素為單位) |
| zoomOffset | Integer | 3 | 主地圖縮放和放大鏡之間的縮放級(jí)別偏移 |
| fixedZoom | Integer | -1 | 放大鏡圖層顯示固定某一層級(jí),不隨地圖比例尺變化而變化 |
| fixedPosition | Boolean | false | 如果為true放大鏡將停留在地圖上的相同位置,而不是跟隨鼠標(biāo)光標(biāo)移動(dòng) |
| latLng | LatLng | [0, 0] | 放大鏡的初始位置,既在主地圖上,又作為放大視圖的中心。 |
| layers | ILayer[] | 空 | 要在放大視圖中顯示的圖層集(請(qǐng)勿使用主地圖已在使用的圖層對(duì)象) |

詳細(xì)源碼(Vue3)
<template>
<div class="app-contain">
<!-- leaflet 地圖容器 -->
<div id="myMap"></div>
</div>
</template>
<script setup>
// 引入樣式
import L from 'leaflet';
import 'leaflet/dist/leaflet.css'
// 引入地圖放大鏡
import './store/leaflet.magnifyingglass.css'
import './store/leaflet.magnifyingglass.js'
import {onMounted} from 'vue'
const initMap = () => {
// 影像地圖
const sourceMap = L.tileLayer('https://tiles1.geovisearth.com/base/v1/img/{z}/{x}/{y}?token=yours_token');
const layers = L.layerGroup([sourceMap])
let map = L.map('myMap', { //需綁定地圖容器div的id
attributionControl: false,
zoomControl: true, // 顯示縮放控件
// 最小顯示等級(jí)
minZoom: 1,
// 最大顯示等級(jí)
maxZoom: 18,
// crs: L.CRS.EPSG3857,//設(shè)置坐標(biāo)系類型 EPSG3857偽墨卡托投影
scrollWheelZoom: true, //默認(rèn)開(kāi)啟鼠標(biāo)滾輪縮放
// 限制顯示地理范圍
maxBounds: L.latLngBounds(L.latLng(-90, -180), L.latLng(90, 180)),
// 限制顯示地理范圍
layers: [layers] // 圖層
}).setView([28.907459, 120.003576], 6)
// 比例尺
L.control.scale({maxWidth: 240, metric: true, imperial: false, position: 'bottomleft'}).addTo(map);
/** 地圖放大鏡 */
const baseLayer1 = L.tileLayer('https://tiles1.geovisearth.com/base/v1/vec/{z}/{x}/{y}?token=yours_token');
const vecLayer = L.layerGroup([baseLayer1])
// 創(chuàng)建地圖放大鏡圖層,并添加到地圖中
let magnifyingGlass = L.magnifyingGlass({
// 主地圖縮放和放大鏡之間的縮放級(jí)別偏移
zoomOffset: 3,
layers: [vecLayer]
}).addTo(map);
}
onMounted(() => {
initMap()
})
</script>
<style scoped>
#myMap {
width: 96vw;
height: 96vh;
}
</style>到此這篇關(guān)于vue結(jié)合leaflet實(shí)現(xiàn)地圖放大鏡的文章就介紹到這了,更多相關(guān)vue leaflet地圖放大鏡內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue包大小優(yōu)化的實(shí)現(xiàn)(從1.72M到94K)
這篇文章主要介紹了Vue包大小優(yōu)化的實(shí)現(xiàn)(從1.72M到94K),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
webpack如何將vue3單頁(yè)面應(yīng)用改造成多頁(yè)面應(yīng)用
這篇文章主要介紹了webpack如何將vue3單頁(yè)面應(yīng)用改造成多頁(yè)面應(yīng)用,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05
Vue.js bootstrap前端實(shí)現(xiàn)分頁(yè)和排序
vue實(shí)現(xiàn)在data里引入相對(duì)路徑

