问题背景
收到紧急BUG,APP放到后台的之后,过一段时间再回到前台偶发多了一层蒙层(其实就是Dialog的Dim效果)。由于该Dialog不可按返回取消,又不能点击外面取消。所以阻止了进一步的交互。现象就是应用上有一层半透明灰色前景,实测在三星S9+上,完全不可交互。但是在小米8上,可以透过蒙层进行交互。
问题分析
当应用在后台的时候,如果弹窗的DecorView没有写死宽高,在Android10上会出现不测量,不布局的现象。没有去分析源码,就简单打了几个log看了一下。暂时只在Android10上能复现这个问题,但也不排除别的系统就一定没问题。
问题解决
为Dialog创建一个基类,当Dialog获取到焦点的时候,主要也就是应对从后台回到前台的时候。如果发现Dialog的DecorView宽或者高为0,就去请求布局。这样问题就暂时解决了。
@Override
public void onWindowFocusChanged(boolean hasFocus) {
super.onWindowFocusChanged(hasFocus);
Window window = getWindow();
if (hasFocus && window != null) {
View decorView = window.getDecorView();
if (decorView.getHeight() == 0 || decorView.getWidth() == 0) {
decorView.requestLayout();
Log.d(TAG, "布局异常,重新布局");
}
}
}
后记
此方案在一加上无效。初步测试,在华为,OPPO,VIVO的android10上不存在此BUG。确认在原生android10,小米,一加上存在此BUG。已经向小米和一加提交了BUG,看他们是不是会修复。