如何解决如何使Leaflet弹出窗口跟随光标的位置移动?
我的弹出窗口设置为在mouSEOver
上打开,并且我的地图上的图标很大。现在,当光标移到图标上时,弹出窗口在图标中间保持静止。当光标位于相关图标内时,弹出窗口是否可能随着光标的移动而移动?怎么样?
我正在尝试通过NYT实现类似this的效果,但是要使用Leaflet和markerCluster插件。
相关代码:
var markers = L.markerClusterGroup( {
....
iconCreateFunction: function (cluster) {
cluster.bindPopup(stateBlurb,{offset: new L.Point(0,-15)});
cluster.on('mouSEOver',function (e) {
this.openPopup();
});
cluster.on('click',function (e) {
this.openPopup();
});
cluster.on('clickout',function (e) {
this.closePopup();
});
return L.divIcon({
html: '<div><span>' + stateName + '</span></div>',className: `cluster ${classNameSize} ${classNameColor}`,iconSize: null,});
},});
解决方法
有几种解决方法;其中之一是依靠the openPopup(latlng)
method以及Leaflet-decorated mouse events的latlng
属性和mousemove
事件,例如:
var circle = L.circleMarker([0,0],{radius: 200}).addTo(map);
circle.bindPopup('Hello circle');
circle.on('mouseover',function(ev){ circle.openPopup(ev.latlng); });
circle.on('mousemove',function(ev){ circle.openPopup(ev.latlng); });
circle.on('mouseout',function(){ circle.closePopup(); });
这样做的缺点是,如果/当用户将指针移到弹出窗口上方时,将触发mouseout
事件,从而使弹出窗口有效闪烁。这可以通过利用the pointer-events
CSS property来解决,例如:
/* JS */
circle.bindPopup('Hello circle',{className: 'popup-with-no-events'});
/* CSS */
.popup-with-no-events {
pointer-events: none;
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。