uniapp map组件自定义markers标记点

需求是根据后端返回数据在地图上显示标记点,并且根据数据状态控制标记点颜色,标记点背景通过两张图片实现控制

html 复制代码
<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>
js 复制代码
<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>
相关推荐
Z兽兽4 小时前
React@18+Vite项目配置env文件
前端·react.js·前端框架
SuniaWang4 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
A_nanda5 小时前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06266 小时前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~6 小时前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
LegendNoTitle6 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界6 小时前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
BJ-Giser7 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码20358 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
发现一只大呆瓜8 小时前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite