一、可能原因:
硬件问题
驱动问题
绘制问题
窗口调度问题
activity问题
app本身的逻辑问题
二、debug步骤
(1) adb shell screenrecord /sdcard/tt.mp4 如果问题还存在说明这个问题和屏幕硬件驱动或MDP合成有关系。
(2)是不是合成问题:
打开开发者选项,勾选禁用硬件叠加选项.
重新复现问题,如果问题依然复现,说明问题是LCD驱动或者硬件层面导致;
问题不再复现,说明这很大可能是一个MDP合成问题.
(3)underrun问题:
屏幕闪烁规则的半个屏幕的蓝色或者黑色矩形,可能是发生了underrun,
在log中看到显示有关的硬件打印了underrun的log,说明此时发生了underrun.一般是由于平台某个硬件带宽不足引起的。
(4)是不是绘制或者硬件加速问题
如果闪屏只发生在某个特定的路径下,一般基本没有可能是绘制的问题或者GPU的问题,
GPU出现问题,会不分路径的,在除了全屏视频播放之外的所有路径下都可能出现大范围的闪屏,
opengl的log会发现在闪屏的应用打出了海量的opengl error的log,这种情况下,很有可能是发生了硬件损坏。
(5)上层的闪屏问题,很多时候是切换的问题
打开开发者选项,将窗口动画比例,过渡动画比例,以及动画影像时间伸缩效果都设置为10x,可清晰看到切换时候发生了什么问题.
问题一般就是activity或者窗口快速切换让用户产生了屏幕在闪的幻觉, 可以通过查看录像慢放明显的看到不该出现的activity(窗口)出现了,这种问题就是app本身在activity的切换逻辑上有问题.
抓取SurfaceFlinger的dumpsys,以及通过ADT的Hierarchy view查看闪出来的是哪个activity
(6)app使用了某种特殊的动画效果
在开发者选项中的绘图选项中,将三个动画相关的设置都修改为动画已关闭
(7)窗口之间在不正常的频繁切换
手指按着屏幕,log会看到触摸的焦点窗口一直在高速变化