android闪屏问题

一、可能原因:

硬件问题

驱动问题

绘制问题

窗口调度问题

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会看到触摸的焦点窗口一直在高速变化

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值