Flutter Android端啟動白屏問題的解決
問題描述
Flutter 應(yīng)用在 Android 端上啟動時會有一段很明顯的白屏現(xiàn)象,白屏的時長由設(shè)備的性能決定,設(shè)備性能越差,白屏?xí)r間越長。
問題分析
其實啟動白屏的問題在Android原生應(yīng)用上也是一個常見問題,大致是因為從用戶點擊 Launcher Icon 到應(yīng)用首頁顯示之間,Android 系統(tǒng)在完成應(yīng)用的初始化工作,其流程如下:

在 Flutter Android 端上,白屏的問題會更加嚴(yán)重,因為除了 Android 應(yīng)用啟動耗時外,還增加了 Flutter 初始化耗時。

直到 Flutter 渲染出第一幀內(nèi)容,用戶才能感知到App啟動完成。
解決方案
解決方案很簡單,Android原生的白屏問題可以通過為 Launcher Activity 設(shè)置 windowBackground 解決,而 Flutter 也是基于此辦法,同時優(yōu)化了 Flutter 初始化階段的白屏問題(覆蓋一個launchView),只用兩步設(shè)置便能解決 Flutter 中白屏問題。
在項目的 android/app/src/main/res/mipmap-xhdpi/ 目錄下添加閃屏圖片;
打開 android/app/src/main/res/drawable/launch_background.xml 文件,這個文件就是閃屏的背景文件,具體如何設(shè)置可以查閱 Android Drawable,我在 demo 中的設(shè)置如下:
<?xml version="1.0" encoding="utf-8"?>
<!-- Modify this file to customize your launch splash screen -->
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@android:color/background_dark" />
<!-- You can insert your own image assets here -->
<item
android:bottom="84dp">
<bitmap
android:src="@mipmap/launch_image" />
</item>
</layer-list>
效果對比如下:

白屏

白屏優(yōu)化
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android InputMethodManager輸入法簡介
這篇文章主要介紹了Android InputMethodManager輸入法框架的使用,具有參考價值,需要的朋友可以參考下。2016-06-06
Android帶進度條的文件上傳示例(使用AsyncTask異步任務(wù))
這篇文章主要介紹了Android帶進度條的文件上傳示例(使用AsyncTask異步任務(wù)),使用起來比較方便,將幾個方法實現(xiàn)就行,感興趣的小伙伴們可以參考一下。2016-11-11
Android中檢查網(wǎng)絡(luò)連接狀態(tài)的變化無網(wǎng)絡(luò)時跳轉(zhuǎn)到設(shè)置界面
這篇文章主要介紹了Android中檢查網(wǎng)絡(luò)連接狀態(tài)的變化無網(wǎng)絡(luò)時跳轉(zhuǎn)到設(shè)置界面,需要的朋友可以參考下2017-06-06
Android ItemDecoration 實現(xiàn)分組索引列表的示例代碼
本篇文章主要介紹了Android ItemDecoration 實現(xiàn)分組索引列表的示例代碼,具有一定的參考價值,有興趣的可以了解一下2017-10-10

