BigLong.Top

Android应用启动瞬间白屏

Apr 17, 2017
目录 [技术文章]
标签 [Android Bug]
字数 [760]

Android App 启动白屏问题,老司机当然不会允许自己的应用出现这种情况!

问题

遇到用户反映在打开app的时候有大概不到一秒钟的白屏时间,无论怎样优化启动Activity ,这个白屏时间都无法避免(也有可能是黑屏)。这个问题不简单啊!然后果断去尝试启动一些比较成熟的应用,例如,摩拜、咸鱼、得到、WhatsApp、Quora、 等等都有白屏问题(其中摩拜是黑屏问题)。不过微信、qq、百度云、微博都没有这个问题,ofo小黄车也没有白屏问题,哈哈哈。

那么问题来了?

启动白屏.gif

到底是什么原因导致了这个白屏or黑屏时间?

解决

先去搜索引擎找一下答案,第一个搜索结果就解决了这个问题。

搜索:Android Splash

之前的启动页就是按照普通的Activity思路去写的,如下:

/**
 * Created by biglong on 2017/4/17.
 */
public class SplashActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_splash);

        //据说,不推荐这种写法,容易内存泄漏
        new Handler().postDelayed(
                new Runnable() {
                    @Override
                    public void run() {
                        startActivity(new Intent(SplashActivity.this
                                ,MainActivity.class));
                        finish();
                    }
                }, 1000
        );
    }
}

问题可能就出现在方法 setContentView 上。我们按照 博客 上面的方法来重新设计该启动页:

创建 XML Drawable

    #在 res/drawable/ 里面

    <?xml version="1.0" encoding="utf-8"?>
    <layer-list   xmlns:android="http://schemas.android.com/apk/res/android">
      <bitmap
        android:gravity="center"
        android:src="@mipmap/splash"/>
    </item>

创建 SplashTheme

    #在 res/values/styles.xml 里面

    <style name="Splash" parent="Theme.AppCompat.DayNight.NoActionBar">
        <item name="android:windowFullscreen">true</item>
        <item name="android:windowBackground">@mipmap/splash</item>
    </style>

声明 SplashActivity

    #在 AndroidManifest.xml 里面
    #注释掉 setContentView(R.layout.activity_splash);

    <activity
        android:name=".SplashActivity"
        android:theme="@style/Splash">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

最后看一下成果

Splash.gif

总结

Splash 可以用来展示公司的Slogan、图标等等,这些都可以用 layer-list 来解决,可以防止图像变形,当然、暴力一点直接用一张背景图也是可以的。。。

至此,白屏黑屏问题就解决了,这么一看其实很简单,就是不用setContentView 方法。而是通过设置 Theme 的 windowBackGround 来实现展示 Splash。

不过为什么 setContentView 会导致白屏还没有深入研究,附上源码,暂时没看出名堂。

    /**
     * Set the activity content from a layout resource.  The resource will be
     * inflated, adding all top-level views to the activity.
     *
     * @param layoutResID Resource ID to be inflated.
     *
     * @see #setContentView(android.view.View)
     * @see #setContentView(android.view.View, android.view.ViewGroup.LayoutParams)
     */
    public void setContentView(@LayoutRes int layoutResID) {
        getWindow().setContentView(layoutResID);
        initWindowDecorActionBar();
    }

Splash 的初衷是为了减少用户应为等待App初始化带来的焦虑感,反应慢等。因此 Splash要控制在3秒钟以内,现在看看一些大厂的手机应用,动不动就是 5S 的 Splash 广告。。。哎。。。