Android SplashScreen開屏廣告優(yōu)化

最近有個(gè)開屏廣告的需求,小伙伴做出來的效果不是很好挡闰。

需求是這樣的

  • 支持播放視頻,gif,以及顯示圖片

問題

  • 閃屏和顯示開屏廣告之間的會(huì)有白色或者黑色間隔

這里視頻播放我們沒有使用VideoView而是直接采用的是Mediaplay加自定義View繼承SurfaceView,目的是減少不必要的冗余邏輯,因?yàn)閂ideoView內(nèi)部維護(hù)了MediaController一個(gè)用來做播控的組件秩伞。

Android 11之前啟動(dòng)app出現(xiàn)的閃屏,我們一般是通過設(shè)置啟動(dòng)頁的
WindowsBackgroud去實(shí)現(xiàn)欺矫,這樣從用戶點(diǎn)開App到看到app啟動(dòng)的過程響應(yīng)速度看起來是很快的纱新,整個(gè)過程過渡比較流暢。

但是Android 11之后穆趴,Android強(qiáng)制app使用了一套SpashScreen機(jī)制脸爱。閃屏被細(xì)化成了多個(gè)屬性,細(xì)節(jié)不去討論未妹,這次主要不是講這個(gè)簿废。
Android引入強(qiáng)制閃屏機(jī)制的本意是指定一個(gè)統(tǒng)一標(biāo)準(zhǔn),讓點(diǎn)開app的體驗(yàn)顯的更加流暢络它,如果你沒有設(shè)置閃屏屬性族檬,默認(rèn)會(huì)把啟動(dòng)LOGO放到屏幕中央,中央的logo區(qū)域根據(jù)不同的廠家還有手機(jī)不同化戳,區(qū)域大小也不一樣导梆,當(dāng)然下方還有個(gè)Banner Logo顯示區(qū)域。

這里因?yàn)锳ndroid 11的這套機(jī)制導(dǎo)致閃屏到開屏廣告中間在低端機(jī)上有一段白屏過程迂烁。
通過排查打印顯示的時(shí)間間隔看尼,播放的資源都是提前預(yù)載好的本地資源,播放視頻初始化只有200ms盟步,顯示gif卻有1s間隔藏斩,導(dǎo)致白屏很明顯,手機(jī)性能好也會(huì)有一瞬間的閃爍(因?yàn)槭褂玫臏y(cè)試機(jī)很老却盘,硬件配置很差狰域,主要也是為了兼容低配手機(jī))。

Android11的閃屏機(jī)制黄橘,官方介紹是從啟動(dòng)app兆览,到顯示界面的第一幀的時(shí)候就會(huì)把界面顯示到前臺(tái)。

Android 12之前還好塞关,可以直接設(shè)置背景透明抬探,這樣從閃屏到開屏廣告過渡比較平滑,但是Android 11之后,官方的SplashScreen關(guān)閉機(jī)制不可控小压,第一幀顯示的時(shí)候就會(huì)立馬消失.原因是


image.png

控制時(shí)間的xml屬性最大推薦時(shí)間是1s內(nèi)线梗。
那有沒有什么辦法延長(zhǎng)這個(gè)時(shí)間呢?答案當(dāng)然是有的怠益。

  • 在splashScreen兼容庫(kù)里有這么一個(gè)api仪搔,可以通過一個(gè)接口控制Splash Screen顯示的時(shí)間。


    image.png

所以我們可以在SplashActivity中加入如下代碼蜻牢,isLoading表示當(dāng)前啟動(dòng)流程還在加載中烤咧。

installSplashScreen().apply {
            setKeepVisibleCondition(SplashScreen.KeepOnScreenCondition { return@KeepOnScreenCondition isLoading })
}

查看源碼其實(shí)可以知道它是通過阻塞界面繪制第一幀馍盟。
當(dāng)KeepCondition為true的時(shí)候耘拇,preDraw會(huì)返回false,文檔描述為取消處理當(dāng)前繪制葡兑。dispatchPreDraw則會(huì)返回cancelDraw取消當(dāng)前繪制镀娶。

open fun setKeepVisibleCondition(keepOnScreenCondition: KeepOnScreenCondition) {
            splashScreenWaitPredicate = keepOnScreenCondition
            val contentView = activity.findViewById<View>(android.R.id.content)
            val observer = contentView.viewTreeObserver
            observer.addOnPreDrawListener(object : OnPreDrawListener {
                override fun onPreDraw(): Boolean {
                    if (splashScreenWaitPredicate.shouldKeepOnScreen()) {
                        return false
                    }
                    contentView.viewTreeObserver.removeOnPreDrawListener(this)
                    mSplashScreenViewProvider?.let(::dispatchOnExitAnimation)
                    return true
                }
            })
        }
image.png

image.png

因?yàn)槲也粶?zhǔn)備引入官方的splashScreen,所以跳過現(xiàn)象看本質(zhì)揪罕,用下面這段代碼自己實(shí)現(xiàn)梯码。在app啟動(dòng)廣告或者application#Oncreate調(diào)用成功之后,然后再把enableFirstFrame值設(shè)置為true好啰。
效果也是一樣的轩娶。保險(xiǎn)起見這邊建議增加一個(gè)定時(shí)器在3-5s之后檢查enableFirstFrame是否為true,否則阻塞太長(zhǎng)時(shí)間框往,怕影響用戶體驗(yàn)鳄抒。


image.png
dependencies {  
 implementation "androidx.core:core-splashscreen:1.0.0"  
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市椰弊,隨后出現(xiàn)的幾起案子许溅,更是在濱河造成了極大的恐慌,老刑警劉巖秉版,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件贤重,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡清焕,警方通過查閱死者的電腦和手機(jī)并蝗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來秸妥,“玉大人滚停,你說我怎么就攤上這事≈嗑澹” “怎么了键畴?”我有些...
    開封第一講書人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)突雪。 經(jīng)常有香客問我镰吵,道長(zhǎng)檩禾,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任疤祭,我火速辦了婚禮盼产,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘勺馆。我一直安慰自己戏售,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開白布草穆。 她就那樣靜靜地躺著灌灾,像睡著了一般。 火紅的嫁衣襯著肌膚如雪悲柱。 梳的紋絲不亂的頭發(fā)上锋喜,一...
    開封第一講書人閱讀 49,772評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音豌鸡,去河邊找鬼嘿般。 笑死,一個(gè)胖子當(dāng)著我的面吹牛涯冠,可吹牛的內(nèi)容都是我干的炉奴。 我是一名探鬼主播,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼蛇更,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼瞻赶!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起派任,我...
    開封第一講書人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤砸逊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后掌逛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體痹兜,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年颤诀,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了字旭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡崖叫,死狀恐怖遗淳,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情心傀,我是刑警寧澤屈暗,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響养叛,放射性物質(zhì)發(fā)生泄漏种呐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一弃甥、第九天 我趴在偏房一處隱蔽的房頂上張望爽室。 院中可真熱鬧,春花似錦淆攻、人聲如沸阔墩。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽啸箫。三九已至,卻和暖如春伞芹,著一層夾襖步出監(jiān)牢的瞬間忘苛,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來泰國(guó)打工唱较, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留扎唾,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓绊汹,卻偏偏與公主長(zhǎng)得像稽屏,于是被迫代替她去往敵國(guó)和親扮宠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子西乖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容