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

vue結(jié)合leaflet實(shí)現(xiàn)地圖放大鏡

 更新時(shí)間:2023年06月26日 15:16:57   作者:努力搬磚的giser  
放大鏡在很多地方都可以使用的到,本文主要介紹了vue結(jié)合leaflet實(shí)現(xiàn)地圖放大鏡,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

本文介紹了Web端使用 Leaflet開發(fā)庫顯示地圖放大鏡的方法 (底圖來源:中科星圖),結(jié)合 leaflet.magnifyingglass插件可以為Leaflet圖層添加“放大鏡”效果,能夠以不同的縮放比例顯示地圖的一部分 ,顯示效果如下圖所示。

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

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

Leaflet插件:leaflet.magnifyingglass

使用教程

安裝依賴庫

通過github倉庫下載,引入項(xiàng)目中

leaflet.magnifyingglass倉庫 https://github.com/bbecquet/Leaflet.MagnifyingGlass

克隆leaflet.magnifyingglass倉庫,下載完畢后,進(jìn)入Leaflet.MagnifyingGlass文件夾,將該目錄下的leaflet.magnifyingglass.jsleaflet.magnifyingglass.css引入本地項(xiàng)目中。

# 克隆leaflet.magnifyingglass倉庫
git clone https://github.com/bbecquet/Leaflet.MagnifyingGlass.git

使用簡介

// 創(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)描述
radiusInteger100放大鏡的半徑(以像素為單位)
zoomOffsetInteger3主地圖縮放和放大鏡之間的縮放級(jí)別偏移
fixedZoomInteger-1放大鏡圖層顯示固定某一層級(jí),不隨地圖比例尺變化而變化
fixedPositionBooleanfalse如果為true放大鏡將停留在地圖上的相同位置,而不是跟隨鼠標(biāo)光標(biāo)移動(dòng)
latLngLatLng[0, 0]放大鏡的初始位置,既在主地圖上,又作為放大視圖的中心。
layersILayer[]要在放大視圖中顯示的圖層集(請(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)開啟鼠標(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.js bootstrap前端實(shí)現(xiàn)分頁和排序

    Vue.js bootstrap前端實(shí)現(xiàn)分頁和排序

    這篇文章主要為大家詳細(xì)介紹了Vue.js結(jié)合bootstrap前端實(shí)現(xiàn)分頁和排序效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • vue實(shí)現(xiàn)在data里引入相對(duì)路徑

    vue實(shí)現(xiàn)在data里引入相對(duì)路徑

    這篇文章主要介紹了vue實(shí)現(xiàn)在data里引入相對(duì)路徑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 最新評(píng)論