uniapp小程序地图监听缩放层级

文章讲述了在微信小程序中遇到的问题,即在地图上添加markers后,即使缩放到最大层级仍有大量图标显示。作者通过监听地图视野移动,使用定时器检查缩放级别,并在缩放超过特定阈值时动态添加或删除markers来优化显示。在微信开发工具中遇到了删除marker的显示异常,但在真机上表现正常。作者期待更好的解决方案。
摘要由CSDN通过智能技术生成

        功能需求是在地图上添加makers,但是就算缩放成最大层级,地图上还是会有那么一坨图标,看起来就很丑。。。

        在官方看了文档只有监听地图视野移动的

 只用拖动地图时才会触发。我也没找到官方能监听地图缩放的api所以只能用一个蠢方法去实现了。

首先获取地图对象的上下文,然后在data里复制。写一个定时器每500毫秒触发一次。地图对象有个getScale方法可以获取当前层级。

let _this=this
                let mapContext = uni.createMapContext("map", this);
                this.timer=setInterval(function(){
                    let scale= mapContext.getScale({
                        success(res) {
                            _this.zoom=res.scale
                        }
                    })
                    
                },500)

                                

之后在watch里监听这个zoom层级,然后声明一个值作为makers是否显示的判断,比如我写的是地图放大到16以上才会显示 

	watch:{
			zoom(newVal,oldVal){
				let i=this.showMakerZoom //这是我在data里声明的缩放层级  这个i理解成16就行
				if(newVal>=i&&oldVal<i){
						this.addMakers()  //如果新的缩放层级大于16并且旧的缩放层级小于16就触发这个添加icon的方法
				}else if(newVal<i&&oldVal>=i){
					this.removerMakers() //如果新的缩放层级小于16并且旧的大于16就触发删除icon的方法
				}
			}
		},

对了还有个微信小程序的不知道是bug还是官方故意留的。

 在微信开发工具上如果删除已经添加的maker会变成这样,

 正常放大添加 是没有问题的。 然后在真机上也是没有问题的


如果有更好的解决方法欢迎私信

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值