关于android2.2中浏览器会被白板遮盖的问题

本文详细描述了一个在Android 2.2中浏览器遇到的白屏问题,该问题发生在输入法弹出、隐藏及快速滑动页面后。通过对错误日志的分析,定位到问题与AutoCompleteTextView有关,特别是showDropDown方法。解决方案是在特定条件下限制AutoCompleteTextView生成高度大于0的白板,以避免浏览器被遮盖。然而,这个问题的根本原因在于PopupTouchInterceptor的事件处理,ACTION_DOWN触发后无法收到ACTION_UP,导致事件无法正常回收。
摘要由CSDN通过智能技术生成

强大的测试组居然测出不少android框架级的bug,其中有一个现象如下:

 android2.2中浏览器被白板遮盖

 

故事是这样发生的,当焦点放在地址栏时,会弹出SearchDialog,而在下方会有一个popup window用于显示访问历史,这是输入法也会冒出来,此时,如果隐藏掉输入法(比如按输入法的关闭按钮,或者在listview处滑动)再按back键,重点来了,按back键之后快速滑动浏览器页面,奇迹发生了,浏览器居然被一大块白板给遮盖了!!!

 

起初发现该问题是还是偶发的,但任何一个偶发现象都有其必然规律,终于在不懈的尝试与分析下,发现了上面的必现路径。

 

有事解一个问题真的需要运气,比如这次,我发现,当白板出现时,按menu退出浏览器,这是发现,浏览器再临死前还是留下了凶手的一些蛛丝马迹:

 

android.widget.AutoCompleteTextView.showDropDown(AutoCompleteTextView.java:1207)
01-21 13:14:24.507: ERROR/WindowManager(3834):     at android.widget.AutoCompleteTextView$ResizePopupRunnable.run(AutoCompleteTextView.java:1452)

 

AutoCompleteTextView!!

多么可疑!

毕竟AutoCompleteTextView生活在SearchDialog的世界中,而死者致死的白板多么像一个popupwindow啊,而且死者临死前竟也指出了凶手的手段(AutoCompleteTextView.showDropDown)。

深入AutoCompleteTextView.showDropDown家中调查发现,他平日便是靠着剪裁各种大小的白板(mPopup.setWindowLayoutMode(widthSpec, heightSpec))为生 。在他家偷偷装上摄像头,发现

(noInputMethod == true && !mPopup.isShowing())二者一起出现的时候,浏览器必死!看来是漏网之鱼!

凶手出现了,漏洞找到了,亡羊补牢,为时不晚,于是,法规上增加一条:当mPopup没有显示,并且输入法也不存在的时候,禁止AutoCompleteTextView制造高度大于0 的白板:

if (mPopup.isShowing()) {

……

}else{

if(noInputMethod == true)
    heightSpec = 0;

else if(……){

}else{

}

}

 

这样浏览器从此果然没有再被害。

 

看来google的法规还有待完善啊,其实这种解法仅仅是解决了出口,源头没有封堵。

 

比如,看这个接口:

 

其实问题就出在这,当popupwindow还显示的时候,你触碰TP,他会收到ACTION_DOWN事件,并在250ms后执行showDropDown的动作,但问题就在于,ACTION_DOWN之后,AutoCompleteTextView已经不存在了,本来需要的ACTION_UP事件现在肯定收不到了,这就出现了无法在250ms内将发出去的事件收回,“刀下留人”也来不及了!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值