需求是根据后端返回数据在地图上显示标记点,并且根据数据状态控制标记点颜色,标记点背景通过两张图片实现控制
<map
style="width: 100vw; height: 100vh;"
:markers="markers"
:longitude="locaInfo.longitude"
:latitude="locaInfo.latitude"
@markertap="markerClick"
@callouttap='callouttap'
>
<!-- 使用callout进行自定义 -->
<cover-view slot="callout">
<template v-for="(item,index) in markers">
<cover-view
style="position: relative; width: 100%;padding-right: 20px;"
:marker-id="item.id"
:key='index'>
<cover-view class="marker-box" style="padding: 5px 5px 12px 5px;">
<cover-image class="position-absolute" style="margin-right: 5px; width: 30rpx; height: 30rpx;" :src="item.options.img"></cover-image>
<cover-view>{{item.options.labelName}}</cover-view>
<cover-image class="position-absolute" style="position: absolute; left: 0;top: 0; z-index: -1; width: 100%; height: 100%;" :src="item.options.isStore?item.options.active_bg:item.options.bg"></cover-image>
</cover-view>
<cover-view style="position: absolute; right: 0px; top: 50%; transform: translateY(-65%); z-index: 2 ; width: 16px; height: 16px; border-radius: 50%; background-color: aquamarine;"></cover-view>
</cover-view>
</template>
</cover-view>
</map>
<script>
export default {
data() {
return {
storeIndex:0,
locaInfo: {
longitude:120.445172,
latitude:36.111387
},
markers: [ // 标点列表
{
id: 1, //标记点id
index: 0,
clusterId: 1, //自定义点聚合簇效果时使用
latitude: 36.116874, // 纬度
longitude: 120.441515, // 经度
iconPath: '/static/tm.png',
options: {
isStore: true,
img: '/static/store.png',
bg: '/static/1.png',
active_bg: '/static/2.png',
labelName: '恩豪斯',
name: '建材城名称(蓝鳌路店)',
address: '高新区大学路101号',
time1: '2024-02-28 16:30'
},
// 自定义窗口
customCallout: {
anchorX: 0,
anchorY: 0,
display: "ALWAYS" // 常显
}
},
{
id: 2, //标记点id
index: 1,
clusterId: 1, //自定义点聚合簇效果时使用
latitude: 36.110543, // 纬度
longitude: 120.454837, // 经度
iconPath: '/static/tm.png',
options: {
isStore: false,
img: '/static/store.png',
bg: '/static/1.png',
active_bg: '/static/2.png',
labelName: '恩豪斯1111',
name: '品牌名称(所属建材城)',
address: '高新区大学路101号',
time1: '2024-02-28 16:30',
time2: '2024-02-28 16:30',
},
// 自定义窗口
customCallout: {
anchorX: 0,
anchorY: 0,
display: "ALWAYS" // 常显
}
},
],
}
},
methods: {
callouttap(e){ // 点击气泡
console.log(e.detail);
}
}
}
</script>
<style lang="scss">
// 地图标记点
.marker-box {
position: relative;
display: flex;
// align-items: center;
justify-content: center;
color: #fff;
font-size: 28rpx;
overflow: visible;
}
</style>