vue使用高德地圖實(shí)現(xiàn)軌跡顯隱效果


<template>
<div>
<el-button type="primary" @click="pathShowOrHide">
軌跡顯/隱
</el-button>
<div id="container" />
</div>
</template>
<script>
import AMapLoader from '@amap/amap-jsapi-loader'
export default {
name: 'MapView',
data() {
return {
map: null,
PathSimplifier: null,
$: null,
pathState: true
}
},
mounted() {
this.initAMap()
},
unmounted() {
this.map?.destroy()
},
methods: {
initPage(PathSimplifier, $) {
const pathSimplifierIns = new PathSimplifier({
zIndex: 100,
// autoSetFitView:false,
map: this.map, // 所屬的地圖實(shí)例
getPath: function(pathData, pathIndex) {
return pathData.path
},
getHoverTitle: function(pathData, pathIndex, pointIndex) {
return null
}
})
window.pathSimplifierIns = pathSimplifierIns
pathSimplifierIns.setData([{
name: '測(cè)試',
path: [
[116.405289, 39.904987],
[113.964458, 40.54664],
[111.47836, 41.135964],
[108.949297, 41.670904]
]
}])
const pathNavigatorStyles = [{
width: 16,
height: 24,
content: 'defaultPathNavigator'
}
]
function extend(dst) {
if (!dst) {
dst = {}
}
const slist = Array.prototype.slice.call(arguments, 1)
for (let i = 0, len = slist.length; i < len; i++) {
const source = slist[i]
if (!source) {
continue
}
for (const prop in source) {
if (source.hasOwnProperty(prop)) {
dst[prop] = source[prop]
}
}
}
return dst
}
let idx = 0
const navg1 = pathSimplifierIns.createPathNavigator(0, {
loop: true,
speed: 1000000,
pathNavigatorStyle: extend({}, pathNavigatorStyles[0])
})
navg1.start()
function changeNavgContent() {
// 獲取到pathNavigatorStyle的引用
const pathNavigatorStyle = navg1.getStyleOptions()
// 覆蓋修改
extend(pathNavigatorStyle, pathNavigatorStyles[(++idx) % pathNavigatorStyles.length])
// 重新繪制
pathSimplifierIns.renderLater()
}
setInterval(changeNavgContent, 500)
},
initAMap() {
const that = this
AMapLoader.load({
key: 'ed030cd90d1a6014ea01f26d51250f40', // 申請(qǐng)好的Web端開(kāi)發(fā)者Key,首次調(diào)用 load 時(shí)必填
version: '2.0', // 指定要加載的 JSAPI 的版本,缺省時(shí)默認(rèn)為 1.4.15
plugins: ['AMap.Scale'], // 需要使用的的插件列表,如比例尺'AMap.Scale',支持添加多個(gè)如:['...','...']
AMapUI: {
version: '1.1',
plugins: ['overlay/SimpleMarker']
}// 需要使用的的插件列表,如比例尺'AMap.Scale'等
})
.then((AMap) => {
this.map = new AMap.Map('container', {
// 設(shè)置地圖容器id
viewMode: '3D', // 是否為3D地圖模式
zoom: 4, // 初始化地圖級(jí)別
center: [116.397428, 39.90923] // 初始化地圖中心點(diǎn)位置
})
AMapUI.load(['ui/misc/PathSimplifier', 'lib/$'], (PathSimplifier, $) => {
if (!PathSimplifier.supportCanvas) {
alert('當(dāng)前環(huán)境不支持 Canvas!')
return
}
this.PathSimplifier = PathSimplifier
this.$ = $
this.initPage(PathSimplifier, $)
})
})
.catch((e) => {
console.log(e)
})
},
pathShowOrHide() {
if (this.pathState) {
window.pathSimplifierIns.setData([])
this.pathState = false
} else {
this.initPage(this.PathSimplifier, this.$)
this.pathState = true
}
}
}
}
</script>
<style scoped>
#container {
width: 100%;
height: 300px;
}
</style>到此這篇關(guān)于vue使用高德地圖實(shí)現(xiàn)軌跡顯隱的文章就介紹到這了,更多相關(guān)vue高德地圖軌跡顯隱內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
el-select二次封裝實(shí)現(xiàn)可分頁(yè)加載數(shù)據(jù)的示例代碼
使用el-select時(shí)一次性渲染幾百條數(shù)據(jù)時(shí)會(huì)造成頁(yè)面克頓, 可以通過(guò)分頁(yè)來(lái)實(shí)現(xiàn),所以本文給大家介紹了el-select二次封裝實(shí)現(xiàn)可分頁(yè)加載數(shù)據(jù),文中有詳細(xì)的代碼講解,具有一定的參考價(jià)值,需要的朋友可以參考下2023-12-12
vue點(diǎn)擊Dashboard不同內(nèi)容 跳轉(zhuǎn)到同一表格的實(shí)例
這篇文章主要介紹了vue點(diǎn)擊Dashboard不同內(nèi)容 跳轉(zhuǎn)到同一表格的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
Vue3-新特性defineOptions和defineModel示例詳解
在Vue3.3中新引入了defineOptions宏主要是用來(lái)定義Option API的選項(xiàng),可以用defineOptions定義任意的選項(xiàng),props、emits、expose、slots除外,本文給大家介紹Vue3-新特性defineOptions和defineModel,感興趣的朋友一起看看吧2023-11-11
vue3+typeScript穿梭框的實(shí)現(xiàn)示例
這篇文章主要介紹了vue3+typeScript穿梭框的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
vue開(kāi)發(fā)runtime core中的虛擬節(jié)點(diǎn)示例詳解
這篇文章主要為大家介紹了vue開(kāi)發(fā)runtime core中的虛擬節(jié)點(diǎn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
淺談Vue3.0新版API之composition-api入坑指南
這篇文章主要介紹了Vue3.0新版API之composition-api入坑指南,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04

