Android 日常使用程序员技术栈

Anroid 性能优化之一:黑白屏的产生和优化

2019-06-12  本文已影响135人  宾格66

来点前奏说明

当你打开这个文档的时候,你已经做好准备了,话不多说开搞。

1、黑白屏产生原因:

在AndroidManifest.xml的Application的theme没有配置主题就是黑屏,配置了就是白屏。市面上App有些还是可以看到的黑白屏的,光大银行白屏、个人所得税黑屏。。。

  • 白屏寻找之路
1.找到style的AppTheme(我的是这个,使用默认的)
2.点父样式,一直点父样式,直到  Platform.AppCompat.Light 在这个里面有个属性
      <item name="android:windowBackground">@color/background_material_light</item>
3.一直点击颜色直到找到
      <color name="material_grey_50">#fffafafa</color> 
4.这个颜色就是白色
白屏
  • 有同学说自己开发的App看的不明显,可以如下设置
Application的onCreate方法中睡三秒
try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
}
主题添加明显的颜色
    <item name="android:windowBackground">@color/colorPrimary</item>
设置其他颜色的背景色
  • 黑白屏在哪里优化
    一般都是优化Application这个类

2、一般做法(伪优化)

  • 一般做法一:在主题下设置张图片遮挡一下
      <item name="android:windowBackground">@drawable/bg</item>
  • 一般做法二:设置为透明,这个会出现点击等待一段时间才出来
      <item name="android:windowIsTranslucent">true</item>
  • 一般做法三:背景设置为空并且不加载,这个会导致每个activity都出现这个屏幕
        <!--背景设置为空-->
        <item name="android:windowBackground">@null</item>
        <!--不加载-->
        <item name="android:windowDisablePreview">true</item>
  • 一般做法四:在方法三上面优化
   1.在style.xml中增加一个主题
    <style name="AppTheme.Launcher" parent="AppTheme">
        <!--背景设置为空-->
        <item name="android:windowBackground">@null</item>
        <!--不加载-->
        <item name="android:windowDisablePreview">true</item>
    </style>
    2.在清单文件找到主页面,设置上面的主题
      android:theme="@style/AppTheme.Launcher"
    3.在主页面的onCreate方法内
       setTheme(R.style.AppTheme_Launcher);
  

3、深层优化做法

  • 深层优化做法一:使用系统的类抓取trace文件,这个必须得给App权限(设置---应用---权限)

3.1.1.Application的onCreate方法中刚开始增加

     File file = new File(Environment.getExternalStorageDirectory(), "app.trace");
     Debug.startMethodTracing(file.getAbsolutePath());

3.1.2.结束的时候增加

     Debug.stopMethodTracing();

3.1.3.找到app.trace我是链接电脑就在根目录,拖进AS中分析 选择Top Down

  • 下图是优化之前的图表。


    优化之前的

对于耗时操作,分析是否能否懒加载延时加载,initX5Environment这个方法我放在延时加载,看下效果。一点点分析,这个一定要耐心一点分析,分析之后修改测试。

  • 下图是优化之后的图表,大家仔细看下优化后的时间。


    优化之后的

宾格设计公众号(主要介绍技术和对象)

宾格设计

FAQ

问题和答疑

上一篇下一篇

猜你喜欢

热点阅读