101.在 Vue 3 + OpenLayers 使用 declutter 避免文字標簽重疊

1. 前言

在使用 OpenLayers 進行地圖開發時,我們經常需要在地圖上添加點、線、區域等圖形,并給它們附加文字標簽。但當地圖上的標注較多時,文字標簽可能會發生重疊,導致用戶無法清晰地查看地圖信息。

幸運的是,OpenLayers 提供了 declutter 選項,能夠有效地避免文字標簽的重疊問題。本文將介紹如何在 Vue 3 + OpenLayers 項目中使用 declutter,并通過示例代碼展示如何添加帶有時間標簽的軌跡點。


2. declutter 介紹

declutter 是 OpenLayers VectorLayer(矢量圖層)的一個屬性,專門用于處理標注(文本或圖標)的重疊問題。如果 declutter: true,OpenLayers 會自動調整標注的顯示方式,避免文本或圖標重疊在一起,提高地圖的可讀性。


3. 項目環境

  • Vue 3 + Composition API
  • OpenLayers
  • Vite

安裝 OpenLayers

npm install ol

4. 代碼實現

4.1 創建 Vue 組件

我們創建一個 Vue 組件,在其中初始化 OpenLayers 地圖,并使用 declutter 避免標注重疊。

完整代碼

<!--* @Author: 彭麒* @Date: 2025/3/13* @Email: 1062470959@qq.com* @Description: 此源碼版權歸吉檀迦俐所有,可供學習和借鑒或商用。-->
<template><div class="container"><div class="w-full flex justify-center flex-wrap"><div class="font-bold text-[24px]">在Vue3中+OpenLayers使用declutter,避免文字標簽重疊</div></div><div id="vue-openlayers"></div></div>
</template><script setup>
import "ol/ol.css";
import {onMounted, ref} from "vue";
import {Map, View} from "ol";
import Tile from "ol/layer/Tile";
import OSM from "ol/source/OSM";
import VectorLayer from "ol/layer/Vector";
import VectorSource from "ol/source/Vector";
import Style from "ol/style/Style";
import Icon from "ol/style/Icon";
import Text from "ol/style/Text";
import Fill from "ol/style/Fill";
import Stroke from "ol/style/Stroke";
import Feature from "ol/Feature";
import {Point, LineString} from "ol/geom";
import startPoint from "@/assets/OpenLayers/startPoint.png";
import endPoint from "@/assets/OpenLayers/endPoint.png";
import pointImg from "@/assets/OpenLayers/point.png";
const map = ref(null);
const trackSource = new VectorSource();
const markersData = ref([[111.44, 24.18, 1604627953],[112.26, 24.48, 1604714353],[113.96, 24.65, 1604800753],[113.44, 24.78, 1604887153],[113.44, 24.98, 1605059953],[113.54, 25.68, 1605146353],
]);const setTrackStyle = (text, img) => {return [new Style({image: new Icon({src: img,anchor: [0.5, 0.5],scale: 0.2,}),text: new Text({font: "12px sans-serif",maxAngle: 30,offsetY: 20,text: text,fill: new Fill({color: "#fff"}),backgroundFill: new Fill({color: "rgba(255,0,0,0.6)"}),backgroundStroke: new Stroke({color: "rgba(255,0,0,0.6)", width: 8}),}),}),];
};const showTrace = (data) => {const lineFeature = new Feature(new LineString(data));lineFeature.setStyle(new Style({stroke: new Stroke({color: "#00f", width: 2})}));trackSource.addFeature(lineFeature);const features = [];data.forEach((point, index) => {let img;if (index === 0) img = startPoint;else if (index === data.length - 1) img = endPoint;else img = pointImgconst feature = new Feature({geometry: new Point([point[0], point[1]]),data: point,});const time = new Date(point[2] * 1000).toISOString().split("T")[0];feature.setStyle(setTrackStyle(`時間: ${time}`, img));features.push(feature);});trackSource.addFeatures(features);
};const initMap = () => {const OSMlayer = new Tile({source: new OSM()});const trackLayer = new VectorLayer({source: trackSource,declutter: true, // 避免標簽重疊});map.value = new Map({target: "vue-openlayers",layers: [OSMlayer, trackLayer],view: new View({center: [113.448, 23.986],zoom: 7,projection: "EPSG:4326",}),});
};onMounted(() => {initMap();showTrace(markersData.value);
});</script><style scoped>
.container {width: 840px;height: 590px;margin: 50px auto;border: 1px solid #42B983;
}#vue-openlayers {width: 800px;height: 470px;margin: 0 auto;border: 1px solid #42B983;position: relative;
}
</style>

5. 代碼解析

5.1 setTrackStyle 方法

該方法用于給軌跡點設置樣式:

  • 圖標:設置 Icon 作為點的標識
  • 文本:使用 Text 組件顯示時間,并設置 fillbackgroundFill 等屬性
  • 避免重疊:OpenLayers 通過 declutter 自動處理文字的布局,防止多個標注擠在一起

5.2 showTrace 方法

  • 繪制軌跡線路:使用 LineString 創建軌跡線
  • 添加軌跡點:遍歷 markersData 數據,為每個點創建 Feature
  • 設置時間標簽:使用 setTrackStyle 給每個點添加時間信息

5.3 initMap 方法

  • 創建地圖實例
  • 添加 OSM 瓦片地圖
  • 添加 VectorLayer(啟用 declutter

6. declutter 前后效果對比

在未啟用 declutter 時,多個標注可能會重疊在一起,影響閱讀:

開啟 declutter 后,OpenLayers 會自動優化文本排布,防止文字疊加:


7. 結論

本文介紹了如何在 Vue 3 + OpenLayers 項目中使用 declutter 避免文字標簽重疊。declutter 是 OpenLayers 提供的強大功能,能夠自動優化地圖標注,使得地圖數據更加清晰可讀。希望本文對你有所幫助!

如果覺得有用,請點贊收藏支持!🚀
📢 關注我,獲取更多前端 & GIS 開發技巧!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/897744.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/897744.shtml
英文地址,請注明出處:http://en.pswp.cn/news/897744.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

18天 - 常見的 HTTP 狀態碼有哪些?HTTP 請求包含哪些內容,請求頭和請求體有哪些類型?HTTP 中 GET 和 POST 的區別是什么?

常見的 HTTP 狀態碼有哪些&#xff1f; HTTP 狀態碼用于指示服務器對客戶端請求的響應結果&#xff0c;常見的 HTTP 狀態碼可以分為以下幾類&#xff1a; 1. 信息類&#xff08;1xx&#xff09; 100 Continue&#xff1a;客戶端應繼續發送請求。101 Switching Protocols&…

IXTUR氣控永磁鐵:以高精度氣控和穩定磁場,為機器人應用提供穩定抓取力

在現代工業生產和物流領域&#xff0c;物料的抓取與搬運是影響生產效率和成本控制的重要環節。傳統夾爪在面對不同材質、形狀和重量的物體時&#xff0c;常常存在適應性差、抓取不穩定、操作復雜等問題&#xff0c;導致生產流程中頻繁出現停機調整&#xff0c;增加了人工干預成…

江科大51單片機筆記【16】AD/DA轉換(下)

寫在前言 此為博主自學江科大51單片機&#xff08;B站&#xff09;的筆記&#xff0c;方便后續重溫知識 在后面的章節中&#xff0c;為了防止篇幅過長和易于查找&#xff0c;我把一個小節分成兩部分來發&#xff0c;上章節主要是關于本節課的硬件介紹、電路圖、原理圖等理論知識…

【C++】 —— 筆試刷題day_4

刷題day_4 繼續加油&#xff01;&#xff01;&#xff01; 一、Fibonacci數列 題目鏈接&#xff1a;Fibonacci數列 題目解析 題目要求&#xff0c;輸入一個數N&#xff0c;我們可以對N進行1/-1操作&#xff1b;題目讓我們輸出對N進行至少多少步可以變成Fibonacci數。 這里題目…

IP層之分片包的整合處理---BUG修復

在之前章節中&#xff0c;筆者就IP層之分片包的整合處理進行了概念介紹&#xff0c;以及代碼編寫和仿真&#xff0c;在整體代碼調試環節&#xff0c;筆者發現了一個問題&#xff0c;在本文中&#xff0c;筆者將就這個BUG進行說明&#xff0c;以及進行修復&#xff0c;講解代碼實…

修復Electron項目Insecure Content-Security-Policy(內容安全策略CSP)警告的問題

將以下代碼粘貼進html的<header>標簽內 <metahttp-equiv"Content-Security-Policy"content"default-src self; style-src self unsafe-inline; img-src self data:; "> 解釋一下上面代碼中的屬性含義 default-src self&#xff1a;配置加載策…

linux 的免密切換用戶PAM配置

/etc/pam.d/su是Linux系統中與用戶切換&#xff08;su命令&#xff09;相關的PAM&#xff08;Pluggable Authentication Modules&#xff0c;可插拔認證模塊&#xff09;配置文件。以下是對它的詳細介紹&#xff1a; 簡介 作用 PAM是一種用于管理系統認證的機制&#xff0c;…

pyspark 數據處理的三種方式RDD、DataFrame、Spark SQL案例

目錄 一、淺語二、三種數據處理方式比較2.1 RDD2.2 DataFrame2.3 Spark SQL 三、三種方法的創建方式3.1 創建RDD3.2 創建DataFrame3.2.1 創建sqlContext3.2.2 定義Schema3.2.3 創建DataFrame 3.3 創建SparkSQL3.3.1 登錄臨時表3.3.2 使用sparkSQL 四、三種方法顯示部分字段4.1 …

文件解析漏洞靶機---- 練習通關攻略

1.安裝靶機 點擊 hackme.ova 文件&#xff0c;直接導入虛擬機&#xff0c;選擇存儲位置 2. 開啟靶機 3. kali掃描同C段的ip&#xff0c;找到靶機ip nmap 192.168.182.1/24 經判斷&#xff0c;靶機ip為&#xff1a;192.168.182.157 開啟端口 http 80 、ssh 遠程連接 22 4…

信號處理抽取多項濾波的數學推導與仿真

昨天的《信號處理之插值、抽取與多項濾波》&#xff0c;已經介紹了插值抽取的多項濾率&#xff0c;今天詳細介紹多項濾波的數學推導&#xff0c;并附上實戰仿真代碼。 一、數學變換推導 1. 多相分解的核心思想 將FIR濾波器的系數 h ( n ) h(n) h(n)按相位分組&#xff0c;每…

【大模型基礎_毛玉仁】2.3 基于 Encoder-only 架構的大語言模型

更多內容&#xff1a;XiaoJ的知識星球 目錄 2.3 基于Encoder-only 架構的大語言模型2.3.1 Encoder-only 架構2.3.2 BERT 語言模型1&#xff09;BERT 模型結構2&#xff09;BERT 預訓練方式3&#xff09;BERT 下游任務 2.3.3 BERT 衍生語言模型1&#xff09;RoBERTa 語言模型2&a…

AIP-165 按條件刪除

編號165原文鏈接https://google.aip.dev/165狀態批準創建日期2019-12-18更新日期2019-12-18 有時API需要提供一種機制&#xff0c;按照一些過濾參數刪除大量資源&#xff0c;而非提供待刪除的各資源名字。 這是一個稀有的場景&#xff0c;用于用戶一次性刪除數千或更多資源的…

【Maven教程與實戰案例】

文章目錄 前言一、Maven是什么&#xff1f;二、Maven的安裝與配置1. 安裝前置條件2. 下載與配置 Maven3. 驗證安裝 三、Maven的核心概念1. POM.xml 文件2. 構建生命周期與插件機制 四、實戰項目示例1. 項目目錄結構2. 編寫代碼App.javaAppTest.java 3. 構建項目4. 運行項目 前言…

20250310:OpenCV mat對象與base64互轉

代碼: https://github.com/ReneNyffenegger/cpp-base64 指南:https://renenyffenegger.ch/notes/development/Base64/Encoding-and-decoding-base-64-with-cpp/ 實操:

概率論的基本知識

逆概率還不懂&#xff0c;改天再想想。 聯合概率 聯合概率&#xff08;Joint Probability&#xff09; 是概率論中的一個重要概念&#xff0c;用于描述多個隨機變量同時取某些值的概率。聯合概率可以幫助我們理解多個變量之間的關系。

pytest數據庫測試文章推薦

參考鏈接&#xff1a; 第一部分&#xff1a;http://alextechrants.blogspot.fi/2013/08/unit-testing-sqlalchemy-apps.html第二部分&#xff1a;http://alextechrants.blogspot.fi/2014/01/unit-testing-sqlalchemy-apps-part-2.html

如何自己做奶茶,從此告別奶茶店

自制大白兔奶茶&#xff0c;奶香與茶香激情碰撞&#xff0c;每一口都是香濃與甜蜜的雙重誘惑&#xff0c;好喝到跺腳&#xff01;絲滑口感在舌尖舞動&#xff0c;仿佛味蕾在開派對。 簡單幾步就能復刻&#xff0c;成本超低&#xff0c;輕松在家享受奶茶自由。 材料:大白兔奶糖&…

SOA(面向服務架構)與微服務架構的區別與聯系

SOA&#xff08;面向服務架構&#xff09;與微服務架構的區別與聯系 1. 引言 在現代軟件架構中&#xff0c;SOA&#xff08;Service-Oriented Architecture&#xff0c;面向服務架構&#xff09;和微服務架構&#xff08;Microservices Architecture&#xff09;是兩種常見的…

LLM的準確率評估采用什么方式:準確率評估使用的是 `sklearn.metrics` 模塊中的 `accuracy_score` 函數

LLM的準確率評估采用什么方式:準確率評估使用的是 sklearn.metrics 模塊中的 accuracy_score 函數 評估方式 代碼里的準確率評估是基于每個樣本最后一個預測的 token 與真實的 token 進行對比。具體來說,它會遍歷測試數據集中的每個樣本,使用模型預測出最后一個 token 的 …

文件和異常

從文件中讀取數據 讀取整個文件 讀取整個文件 要讀取文件&#xff0c;需要一個包含幾行文本的文件。下面首先創建一個文件&#xff0c;它包含精確 到小數點后30位的圓周率值&#xff0c;且在小數點后每10位處換行&#xff1a; pi_digits.txt 3.14159265358979323846264338…