微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 手机设计讨论 > MTK手机平台交流 > 进入应用界面后发现会闪屏,此时要如何定位是否是relaunch activity引起的闪屏呢

进入应用界面后发现会闪屏,此时要如何定位是否是relaunch activity引起的闪屏呢

时间:10-02 整理:3721RD 点击:
[DESCRIPTION]
进入应用界面后发现会闪屏,此时要如何定位是否是relaunch activity引起的闪屏呢?
[SOLUTION]
1 对于这类问题,抓取log时记得要打开AMS的log开关:
adb shell dumpsys activity log a on
2 请在main log里搜索Relaunching关键字,看下这个Activity是否有被Relaunching,如果是,那么闪屏就是这个原因了。
3 确定是Relaunching造成的问题后,要如何进一步定位问题呢?
AMS会relaunching activity的原因是:
config发生变化,而activity没有监听对应的config,AMS就会relaunch这个activity,现象上来讲就是屏幕会闪。
我们可以从log里查看下是哪些config发生了变化,然后请app端监听这个config,重写onConfigUARTionChanged这个函数来处理config的变化。那么AMS就不会去relaunch这个activity了。
Apk监听config的方法为:
在apk的androidManifest.xml里设定
<android:configChanges=“Layout_direction|locale|….”>
对于检查是哪些config发生变化,可以看main log。
举例:
V ActivityManager: Checking to restart yuku.perekammp3.ac.DaftarActivity:
changed=0X2004, handles=0x4a4, newConfig={1.0 460mcc2mnc zh_CN ldltr
sw320dp w320dp h508dp 240dpi nrml long port finger -keyb/v/h dpad/v
skin=/system/php?mod=tag&id=6090" target="_blank" class="relatedlink">Framework/framework-res.apk s.11}
请注意红色字体:changed=0x2004
这个changed的值可以在ActivityInfo.java中查询,具体是CONFIG_开头的值。表示的含义就是当前这些config发生了变化。
比如0x2004就是CONFIG_LOCALE|CONFIG_LAYOUT_DIRECTION
注:
1 apk可以监听的config,请查询google的说明文档或者configuration class里的定义
Google的说明文档:
http://developer.android.com/guide/topics/manifest/activity-element.html
2 闪屏有很多原因,这里描述的只是一种。即AMS Relaunch Activity造成的闪屏。
开发人员选项中设置不容许后台进程,进入音乐等退出后此进程依然在后台运行

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top