Vue利用openlayers實現(xiàn)點擊彈窗的方法詳解
這個寫的稍微簡單一點就行了,其實呢,這個不是很難,主要是知道原理就可以了。
我想實現(xiàn)的內容是什么意思呢?就是說頁面上有很多坐標點,點擊坐標點的時候在相應的位置彈出一個框,然后框里顯示出這個坐標點的相關數(shù)據(jù)。
解釋
這個內容的其實就是添加一個彈窗圖層,然后在點擊的時候讓他顯示出來罷了。
編寫彈窗
首先一點,我們這個彈窗需要自己寫一下,具體的樣式,展示的內容之類的,所以說寫一個彈窗組件,然后在openlayer文件中引用加載。
比如我們創(chuàng)建一個 msgModel.vue
<template>
<div class="msg-div">
<p class="msg-title">{{data.title}}</p>
</div>
</template>
<script>
export default {
props: ['data'],
data() {
return {
}
},
methods: {
},
}
</script>
<style scoped>
.msg-div {
min-width: 200px;
padding: 0px;
background-color: #fff;
padding-bottom: 5px;
}
.msg-title {
margin: 0;
padding-left: 5px;
height: 30px;
line-height: 30px;
font-size: 13px;
color: #fff;
}
</style>
上邊是我自己隨便寫的DEMO,然后具體按照你自己的來。
引入
然后在openlayer文件引入。
import msgModel from '@/views/modules/wjw/demo/msgModel'
然后像正常使用子組件一樣加載一下就行。
components: {
msgModel,
},
然后在界面加上。
<msg-model ref="msgForm" :data="data"></msg-model>
其中這個data是傳遞過去要展示的值。
openlayer使用彈窗組件
初始化地圖的時候,我們把這個彈窗加載到openlayer里面。
overlayForm = new Overlay({ // 創(chuàng)建一個圖層
element: this.$refs.msgForm.$el, // 圖層綁定我們上邊的彈窗
autoPan: true,
autoPanAnimation: {
duration: 250,
}
})
overlayForm.setPosition(undefined) // 設置彈窗位置,剛開始我們不讓他顯示,就是undefined就行
map.addOverlay(overlayForm) // 然后把彈窗的圖層加載到地圖上
上面的代碼寫完之后,地圖是沒有彈窗的,因為我沒沒有設置他的位置。
然后實現(xiàn)點擊彈出來。
點擊事件
比如說地圖上有坐標點,我點擊坐標點,然后彈出這個彈框,同時展示點擊坐標點的數(shù)據(jù)信息。
map.on('click', ev => {
let pixel = ev.pixel // 鼠標點擊的位置,這個應該是像素
let mouse = ev.coordinate // 鼠標點擊的坐標位置
let feature = map.forEachFeatureAtPixel(pixel, (feature) => {
return feature // 查找出點擊的哪個坐標
})
if (feature) { // 如果是點擊了坐標點
this.data= feature.get('data') // 獲取坐標點的數(shù)據(jù)
overlayForm.setPosition(mouse) // 設置彈窗的位置
} else {
overlayForm.setPosition(undefined) // 如果沒有點擊坐標點,就隱藏彈窗
}
})
好了,上邊代碼基本上就實現(xiàn)了點擊坐標點彈出信息框功能,就不截圖了,湊合看吧
到此這篇關于Vue利用openlayers實現(xiàn)點擊彈窗的方法詳解的文章就介紹到這了,更多相關Vue openlayers點擊彈窗內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- 在Vue?3中使用OpenLayers加載GPX數(shù)據(jù)并顯示圖形效果
- vue+openlayers+nodejs+postgis實現(xiàn)軌跡運動效果
- Vue使用openlayers加載天地圖
- Vue+OpenLayers?創(chuàng)建地圖并顯示鼠標所在經(jīng)緯度(完整代碼)
- vue?openlayers實現(xiàn)臺風軌跡示例詳解
- vue利用openlayers實現(xiàn)動態(tài)軌跡
- Vue結合openlayers按照經(jīng)緯度坐標實現(xiàn)錨地標記及繪制多邊形區(qū)域
- Vue openLayers實現(xiàn)圖層數(shù)據(jù)切換與加載流程詳解
- Vue使用openlayers實現(xiàn)繪制圓形和多邊形
- 在Vue 3中使用OpenLayers讀取WKB數(shù)據(jù)并顯示圖形效果
相關文章
Element Cascader 級聯(lián)選擇器的使用示例
這篇文章主要介紹了Element Cascader 級聯(lián)選擇器的使用示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07

