首页 > 其他 > 详细

OpenLayers弹窗闪烁问题

时间:2020-04-27 10:41:23      阅读:173      评论:0      收藏:0      [点我收藏+]

  问题:OpenLayers在做预警(gif图片)的弹窗时,鼠标移入gif,图片一直闪烁。

  过程:当点数据要用gif显示的时候,就不能用加载ol.Feature()的方式了,而是借助于ol.Overlay,将图片作为元素放到ol.Overlay中,作为要素的显示方式。但是还要在这个基础上实现鼠标移到gif上弹窗显示信息(我们都知道ol.Overlay大部分是用来做弹窗显示信息的),这个弹窗还要用到ol.Overlay,我借助了第三方ol-ext里面的ol.Overlay.Popup(从名字中也能知道这个弹窗是借用了ol.Overlay,然后自己改造了,所以可以把它当做ol.Overlay一样用),问题就是在ol.Overlay.Popup上再加ol.Overlay.Popup会有问题,基本会有闪烁,偶尔不闪烁。

  原因:当两个ol.Overlay.Popup叠加到一起时就会有问题,具体的原因不想深究了,大概率是因为冒泡问题。

  解决方法:首先要避免两个overlay叠加到一起,所以我们要设置一下偏移参数;第二就是阻止冒泡,设置 stopEvent: false;第三改一下这个参数:insertFirst: false

  参考代码:      

技术分享图片
let warn_overlay = new ol.Overlay.Popup(
                            {
                                popupClass: "tooltips",
                                stopEvent: false,
                                closeBox: false,
                                positioning: ‘center-center‘,
                                autoPan: false,
                                autoPanAnimation: { duration: 250 }
                            });
要素overlay
技术分享图片
 1  //预警弹框
 2     PopUp_overlay0 = new ol.Overlay.Popup({
 3         className: "popup_overlay",
 4         popupClass: "yellowtips", //"tooltips", "warning" "black" "default", "tips", "shadow",
 5         stopEvent: false,
 6         closeBox: false,
 7         //onshow: function () { console.log("You opened the box"); },
 8         //onclose: function () { console.log("You close the box"); },
 9         positioning: ‘center-left‘,
10         //offsetBox: [0, -10, 0, 0],
11         offset: [5, 10],
12         insertFirst: false,
13         autoPan: true,
14         autoPanAnimation: { duration: 250 }
15     });
弹窗overlay

 

参考文章:Openlayers Overlay使用心得

     OpenLayers教程之弹窗(叠置层)

            

OpenLayers弹窗闪烁问题

原文:https://www.cnblogs.com/youzi-xuchongyou/p/12784670.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!