Android Splash启动白/黑屏闪屏现象产生原因与解决办法

惊鸿一瞥

微信的启动页,相信大家都不陌生。 
不知道大家有没有发现一个现象,微信每次启动的时候,是直接进入这个启动页面。 
我的意思是,很多应用,往往会先白屏停顿一下后再进入启动页面(Splash)。为了印证这一点,我把手机上所有的App都点了一遍。选几个例子 
如下图: 
微信: 
这里写图片描述 
斗鱼: 
这里写图片描述 
斗鱼和微信是直接进入了,他们的Splash页面。 
知乎: 
这里写图片描述 
B站: 
这里写图片描述 
知乎和B站要先进入一个白屏,特别是B站,白屏后再进入的Splash页面。

动手实现

想一想,如果让我们自己来写一个Splash页面怎么实现?

  1. 创建SplashActivity样式,我们需要他是启动界面,固定垂直方向,全屏显示
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  1. 设置主题为ThemeSplash
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  1. 设置SplashActivity的布局文件 activity_splash.xml为背景图片的全屏显示
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

4.设置SplashActivity代码,延迟2秒跳转到MainActivity

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

这里写图片描述 
糟糕,出现了白屏。 
而且不止这个应用,把以前写的几个应用都打开看了下,都有出现黑白屏的现象,斗鱼不闪屏

看看斗鱼怎么做的

使用apktool打开斗鱼

  • 1
  • 2
  • 3

先看他的配置清单文件

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

因为是程序入口,很快找到,使用了android:theme="@style/Theme.AppLauncher",那么看看他的样式Theme.AppLauncher怎么实现的

  • 1
  • 2
  • 3

**看到这里,我们发现他居然把@drawable/bg_splash设置成了窗口背景,而这张叫bg_splash的图片就是他们的启动图片(我们的App已经拿过来用了),继续往下看 。 
找到他的SplashActivity布局文件,在他的res目录,根据命名规则他多半使用splash做关键字,搜索 
这里写图片描述 
打开

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24

几个关键词  进入 、@drawable/start_icon_anim@drawable/splash_ad_logo这不就是最开始,进入的广告页面么: 
这里写图片描述
只不过,他的这张图的大图背景,没有配置,很可能是网络获取的。

到这里,我们大致已经清楚了,斗鱼启动是怎么个逻辑

  1. 把启动图bg_splash设置为窗体背景,避免刚刚启动App的时候出现,黑/白屏
  2. 设置为背景bg_splash显示的时候,后台负责加载资源,同时去下载广告图,广告图下载成功或者超时的时候显示SplashActivity的真实样子
  3. 随后进入MainAcitivity 
    据我观察,淘宝启动的时候和斗鱼逻辑是一样的,有兴趣可以探究下。 
    到这里,偷师成功,我们可以回来改自己的程序了。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

这里写图片描述 
好的已经不闪屏了。

为什么会这样

最后,思考一下这个问题,为什么会出现这种情况,在启动Acitivty的onCreate()方法里面,执行setContentView(R.layout.activity_splash);出现白屏。 
设想,onCreate---setContentView这个并不是发生在,窗体绘制的第一步,系统会在执行这个步骤之前,先绘制窗体,这时候布局资源还没加载,于是就使用默认背景色。

扫描二维码关注公众号,回复: 2017749 查看本文章
  • 1

这种亮色系,造成白色闪屏

  • 1

这种暗色系主题,造成了黑色闪屏

代码地址:https://github.com/zhouruikevin/makeapp

猜你喜欢

转载自blog.csdn.net/csdn_aiyang/article/details/80972831