113. 在 Vue 3 中使用 OpenLayers 實現鼠標移動顯示坐標信息

? 寫在前面

在地圖類項目開發中,一個常見需求就是:實時獲取用戶鼠標在地圖上的經緯度坐標,并展示在地圖上。

本文將通過一個簡單的案例,手把手帶大家在 Vue 3 項目中集成 OpenLayers 地圖庫,并實現以下功能:

  • 加載 OpenStreetMap 地圖瓦片

  • 鼠標移動時顯示實時坐標(經緯度)

  • 使用 MousePosition 控件格式化坐標

  • 支持 Vue 3 Composition API


🔧 技術棧

  • Vue 3 + <script setup>

  • Vite 5+ 構建工具(也支持 Vue CLI)

  • OpenLayers v7+

  • 原生 CSS + Tailwind class(可選)


📦 環境安裝

npm install ol

或使用 yarn:

yarn add ol

確保你使用的是 Vue 3 項目結構。如果你還沒有項目,可以用 Vite 快速初始化:

npm create vite@latest vue3-openlayers-demo --template vue 
cd vue3-openlayers-demo 
npm install 
npm install ol 
npm run dev

🧩 核心代碼實現

我們來直接上代碼吧,以下是一個完整的 Vue 組件文件:

MouseCoordinateMap.vue

<!--* @Author: 彭麒* @Date: 2025/4/7* @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實現鼠標在地圖上移動顯示坐標信息</div></div><div id="vue-openlayers" class="map-x"><div class="mouse" ref="mousePositionTxt"></div></div></div>
</template><script setup>
import { onMounted, ref } from 'vue'
import 'ol/ol.css'
import { Map, View } from 'ol'
import Tile from 'ol/layer/Tile'
import { OSM } from 'ol/source'
import * as control from 'ol/control'
import * as coordinate from 'ol/coordinate'const mousePositionTxt = ref(null)
let map = nullconst initMap = () => {map = new Map({target: 'vue-openlayers',controls: control.defaults().extend([new control.MousePosition({coordinateFormat: coordinate.createStringXY(4),projection: 'EPSG:4326',target: mousePositionTxt.value})]),layers: [new Tile({source: new OSM()})],view: new View({projection: 'EPSG:4326',center: [114.064839, 22.548857],zoom: 4})})
}onMounted(() => {initMap()
})
</script><style scoped>
.container {width: 840px;height: 520px;margin: 0 auto;border: 1px solid #42B983;
}
#vue-openlayers {width: 800px;height: 400px;margin: 0 auto;border: 1px solid #42B983;position: relative;
}
.mouse {position: absolute;bottom: 50px;right: 20px;z-index: 10;color: #f00;width: 150px;
}
</style>

📚 關鍵點解析

1?? MousePosition 控件的作用

這是 OpenLayers 內置的控件,用于監聽鼠標事件并展示坐標信息。

new control.MousePosition({ coordinateFormat: coordinate.createStringXY(4), projection: 'EPSG:4326', target: this.$refs.mousePositionTxt 
})

在 Vue 3 Composition API 中,需要使用 ref 拿到 DOM 節點,再綁定到 target

2?? 坐標格式化函數

你可以自定義經緯度顯示格式,比如:

coordinateFormat: (coord) => `經度: ${coord[0].toFixed(4)}, 緯度: ${coord[1].toFixed(4)}`

也可以用內置的 createStringXY(4),表示保留 4 位小數。


? 最終效果截圖

🖱 當你將鼠標移動到地圖上時,右下角會實時顯示當前經緯度坐標,效果如下圖所示:


🎯 小結

通過本篇文章,我們成功實現了一個非常實用的地圖功能:鼠標坐標跟蹤器。這個功能在 GIS、智能駕駛、地圖展示等場景中都非常常見。

本案例核心掌握點:

  • 熟悉 OpenLayers 的基本使用

  • 使用 MousePosition 控件監聽坐標

  • 結合 Vue 3 Composition API 實現邏輯


🙋?♀? 后續擴展建議

  • 鼠標點擊地圖標記點

  • 實時繪制軌跡線

  • 集成地理編碼(坐標轉地址)

  • 加入地圖測量工具(長度/面積)


💬 歡迎交流

如果你在項目中也有地圖相關需求,歡迎在評論區留言交流!覺得有幫助也請點個贊/收藏支持一下,持續分享更多 Vue + 地圖技術干貨!

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

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

相關文章

docker配置redis容器時搭載哨兵節點的情況下配置文件docker-compose.yml示例

1.配置數據節點&#xff08;主從節點&#xff09; version: 3.7 services:master:image: redis:5.0.9container_name: redis-masterrestart: alwayscommand: redis-server --appendonly yesports:- 6379:6379slave1:image: redis:5.0.9container_name: redis-slave1restart: a…

C++建造者模式進化論

還在為 C 對象那 長得令人發指 的構造函數參數列表抓狂嗎&#xff1f;&#x1f92f; 是不是經常在 int hp, int mp, int strength, int faith... 這樣的參數“連連看”中迷失自我&#xff0c;一不小心就把法力值傳給了血量&#xff0c;或者力量值填到了信仰欄&#xff1f;&…

在Ubuntu內網環境中為Gogs配置HTTPS訪問(通過Apache反向代理使用IP地址)

一、準備工作 確保已安裝Gogs并運行在HTTP模式(默認端口3000) 確認服務器內網IP地址(如192.168.1.100) 二、安裝Apache和必要模塊 sudo apt update sudo apt install apache2 -y sudo a2enmod ssl proxy proxy_http rewrite headers 三、創建SSL證書 1. 創建證書存儲目錄…

數據中臺、BI業務訪談(二):組織架構梳理的坑

這是數據中臺、BI業務訪談系列的第二篇文章&#xff0c;在上一篇文章中&#xff0c;我重點介紹了在給企業的業務部門、高層管理做業務訪談之前我們要做好行業、業務知識的功課。做好這些功課之后&#xff0c;就到了實際的訪談環節了。 業務訪談關鍵點 那么在具體業務訪談的時…

spark集群,Stand alone,Hadoop集群有關啟動問題

你的問題是因為 start-all.sh 是 Hadoop 的啟動腳本&#xff08;用于啟動 HDFS 和 YARN&#xff09;&#xff0c;而不是 Spark 的啟動腳本。而你已經通過 start-cluster.sh 啟動了 Hadoop 相關服務&#xff08;HDFS/YARN&#xff09;&#xff0c;再次執行 start-all.sh 會導致服…

Kotlin 通用請求接口設計:靈活處理多樣化參數

在 Kotlin 中設計一個通用的 ControlParams 類來處理不同的控制參數&#xff0c;有幾種常見的方法&#xff1a;方案1&#xff1a;使用密封類&#xff08;Sealed Class&#xff09; sealed class ControlParamsdata class LightControlParams(val brightness: Int,val color: S…

aspark 配置2

編寫Hadoop集群啟停腳本 1.建立新文件&#xff0c;編寫腳本程序 在hadoop101中操作&#xff0c;在/root/bin下新建文件&#xff1a;myhadoop&#xff0c;輸入如下內容&#xff1a; 2.分發執行權限 保存后退出&#xff0c;然后賦予腳本執行權限 [roothadoop101 ~]$ chmod x /r…

Webstorm 使用搜不到node_modules下的JS內容 TS項目按Ctrl無法跳轉到函數實現

將node_modules標記為不排除&#xff0c;此時要把內存改大&#xff0c;不然webstorm中途建立索引時&#xff0c;會因為內存不足&#xff0c;導致索引中途停止&#xff0c;造成后續搜索不出來 更改使用內存設置 內存調為4096 若出現搜不出來js內容時&#xff0c;請直接重啟下該項…

vue-element-plus-admin的安裝

文檔鏈接&#xff1a;開始 | vue-element-plus-admin 之前嘗試按照官方文檔來安裝&#xff0c;運行npm run dev命令卻不能正常打開訪問瀏覽器&#xff0c;換一個方式 首先在目錄下打開命令窗口 1、克隆項目 從 GitHub 獲取代碼 # clone 代碼 git clone https://github.com…

【windows10】基于SSH反向隧道公網ip端口實現遠程桌面

【windows10】基于SSH反向隧道公網ip端口實現遠程桌面 1.背景2.SSH反向隧道3.遠程連接電腦 1.背景 ?Windows 10遠程桌面協議的簡稱是RDP&#xff08;Remote Desktop Protocol&#xff09;?。 RDP是一種網絡協議&#xff0c;允許用戶遠程訪問和操作另一臺計算機。 遠程桌面功…

軟考系統架構設計師之大數據與人工智能筆記

一、大數據架構設計 1. 核心概念與挑戰 大數據特征&#xff1a;體量大&#xff08;Volume&#xff09;、多樣性&#xff08;Variety&#xff09;、高速性&#xff08;Velocity&#xff09;、價值密度低&#xff08;Value&#xff09;。傳統數據庫問題&#xff1a;數據過載、性…

【數據結構 · 初階】- 單鏈表

目錄 一.相關指針知識點 二.鏈表 1.為什么學了順序表還要學鏈表 2.優點 三.實現 1.鏈表的打印 —— 理解鏈表結構 (2) 物理結構圖 2.鏈表的尾插 —— 入門 錯誤寫法&#xff1a;tail ! NULL 總結&#xff1a; 正確代碼物理圖解&#xff1a; (2) 尾插整體代碼 (思考…

按鍵消抖(用狀態機實現)

基于狀態機的設計代碼 module key_filter(clk,rst,key,key_p_flag,key_r_flag,key_state);input clk,rst;input key;output reg key_p_flag;output reg key_r_flag;output reg key_state;reg [1:0]r_key; //后面用來判斷什么時候pedge&#xff0c;什么時候nedgealways…

大數據(7.2)Kafka萬億級數據洪流下的架構優化實戰:從參數調優到集群治理

目錄 一、海量數據場景下的性能之殤1.1 互聯網企業的數據增長曲線1.2 典型性能瓶頸分析 二、生產者端極致優化2.1 批量發送黃金法則2.1.1 分區選擇算法對比 2.2 序列化性能突破 三、消費者端并發藝術3.1 多線程消費模式演進3.1.1 消費組Rebalance優化 3.2 位移管理高階技巧 四、…

MyBatis深度解析與實戰指南:細節完整,從入門到精通

MyBatis深度解析與實戰指南&#xff1a;細節完整&#xff0c;從入門到精通 整理這份筆記&#xff0c;是因為學習 MyBatis 時發現很多教程要么只講基礎 CRUD&#xff0c;要么直接跳到 Spring 整合&#xff0c;對 MyBatis 核心特性講解不全面&#xff0c;基礎部分也不夠完整。實…

【科學技術部政務服務平臺-用戶注冊/登錄安全分析報告】

前言 由于網站注冊入口容易被黑客攻擊&#xff0c;存在如下安全問題&#xff1a; 暴力破解密碼&#xff0c;造成用戶信息泄露短信盜刷的安全問題&#xff0c;影響業務及導致用戶投訴帶來經濟損失&#xff0c;尤其是后付費客戶&#xff0c;風險巨大&#xff0c;造成虧損無底洞…

【Audio開發三】音頻audio中幀frameSize ,周期大小periodsize,緩沖區buffer原理詳解以及代碼流程分析

一、基礎概述 在分析獲取最小幀數前&#xff0c;我們先來了解幾個相關的概念。 1&#xff0c;幀 幀&#xff08;frame&#xff09;&#xff1a;表示一個完整的聲音單元&#xff0c;所謂的聲音單元是指一個采樣樣本。如果是雙聲道&#xff0c;那么一個完整的聲音單元就是 2 個樣…

K8S學習之基礎七十五:istio實現灰度發布

istio實現灰度發布 上傳鏡像到harbor 創建兩個版本的pod vi deployment-v1.yaml apiVersion: apps/v1 kind: Deployment metadata:name: appv1labels:app: v1 spec:replicas: 1selector:matchLabels:app: v1apply: canarytemplate:metadata:labels:app: v1apply: canaryspec…

C++藍橋杯填空題(攻克版)

片頭 嗨~小伙伴們&#xff0c;咱們繼續攻克填空題&#xff0c;先把5分拿到手~ 第1題 數位遞增的數 這道題&#xff0c;需要我們計算在整數 1 至 n 中有多少個數位遞增的數。 什么是數位遞增的數呢&#xff1f;一個正整數如果任何一個數位不大于右邊相鄰的數位。比如&#xf…

【Python】數據結構

【Python】數據結構&#xff1a; Series&#xff1a;1、通過列表創建Series類對象2、顯示地給數據指定標簽索引3、通過字典創建Series類對象4、獲取索引5、獲取數據 DataFrame&#xff1a;1、通過數組創建一個DataFrame類對象2、指定列索引3、指定行索引4、獲取列的數據5、查看…