1. 出现的原因
window默认背景是白色,加载布局需要时间,布局没加载完之前显示的是window背景,所以出现短暂的白屏
2. 初步解决方法
在styles.xml里面的加一个属性即可:
@drawable/welcome_img
意思是设置给window设置一张背景图,这张背景图和WelcomeActivity的图片一样
WelcomeActivity布局加载完成前,我们看到的是window背景图;加载完成后,看到的是WelcomeActivity布局,因为两张图片一样,所以视觉上认为是一样的。
@color/colorPrimary
@color/colorPrimaryDark
@color/colorAccent
@drawable/welcome_img
设置完以后发现2个问题:
在华为手机上,设置沉浸式状态栏时, window会先显示默认状态栏颜色。
因为华为手机有虚拟按键,window窗口是连虚拟按键高度一起算的,而我们的布局不算虚拟键盘高度,导致布局高度变了,因此图片显示也会有一个视觉的差距,如下图:
welcome1.gif
针对上面两个问题,暂时没有发现特别好的解决方法。
初略解决办法:把window状态栏去掉,我们的布局也设为全屏显示,window和WelcomeActivity虚拟按键设置透明可见,这样就不会有视觉上的差距了。
style中添加:
true
true
Activity中
getWindow().addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);
getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
setContentView()
3. 终极解决方案(AS3.0亲测有效)
只需在style中加这个属性,让window透明即可
true
welcome2.gif