高德地图Marker旋转时Label也跟着旋转的问题

最近在项目上用到高德地图, Maker需要标注, 但Label跟着旋转, 搞得标注难以阅读, 搞了好几个方案都不理想, 后来在API中看到了Maker的content参数, 终于被我找到了一个不错的解决办法, 不多说, 看代码:
Label跟着旋转:

                        var marker = new AMap.Marker({
							map: map,
							icon: 'icon.png',
							position: [data[i].carX, data[i].carY],
							angle: 45,
							label: { 'content':'标注', 'direction':'bottom'},
						});

把它修改为:

var marker = new AMap.Marker({
							map: map,
							position: [data[i].carX, data[i].carY],
							content: '<div class="makerlabel"><img src="icon.png" style="transform:rotate(45deg)"></br><div style="border:solid 1px #00a0e9; background-color:#ffffff;position: absolute;">标注</div></div>',
						});

 

### 解决高德地图 Marker Label 闪烁问题 对于高德地图中的Marker标签(Label)出现的闪烁现象,可以采取多种策略来优化和修复这一问题。一种有效的方法是在创建Marker通过`content`属性来自定义其内容并控制动画效果[^2]。 当使用自定义内容的方式处理Marker,可以通过JavaScript动态调整DOM节点的内容而不触发重绘或回流操作,从而减少不必要的性能开销和视觉上的闪烁感。具体来说,在更新Label文本或其他样式之前先暂停任何可能引起页面布局变化的操作,待所有更改完成后一次性应用到文档对象模型上。 另外一个重要方面是确保所使用的图像资源已经预先加载完毕再应用于界面上;未缓存好的图片在网络请求过程中可能会造成短暂空白进而引发闪烁情况的发生。因此建议提前准备好所需的静态文件,并考虑利用浏览器端的技术手段如懒加载等提高效率降低延迟影响用户体验的可能性。 最后值得注意的是如果仍然存在明显的闪烁问题,则可能是由于频繁调用了某些API接口或是设置了不合理的刷新频率所致。此应当审查代码逻辑部分是否存在过度渲染的情况,并适当调节间间隔参数以达到最佳平衡状态。 ```javascript // 创建一个隐藏的div用于预加载图片 let preloadDiv = document.createElement('div'); preloadDiv.style.display = 'none'; document.body.appendChild(preloadDiv); function createPreloadedImage(src) { let img = new Image(); img.src = src; preloadDiv.appendChild(img); } createPreloadedImage('/path/to/your/image.png'); // 使用setTimeout代替setInterval防止过高的刷新率导致闪烁 let blinkTimeout; function toggleBlink(marker, show) { marker.setLabel({ content: `<span style="display:${show ? '' : 'none'}">您的文字</span>`, offset: new AMap.Pixel(0, -25), }); clearTimeout(blinkTimeout); // 清除之前的定器 if (show) { // 如果当前显示则设置下一次隐藏的间 blinkTimeout = setTimeout(() => toggleBlink(marker, false), 500); } else { // 否则反之亦然 blinkTimeout = setTimeout(() => toggleBlink(marker, true), 500); } } ```
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值