Glide4.0后占位圖和過(guò)渡動(dòng)畫(huà)沖突解決方案

在使用Glide4.0后面的版本中,實(shí)現(xiàn)漸入動(dòng)畫(huà)效果一般采用requestBuilder.transition(DrawableTransitionOptions.withCrossFade(fadeDuration))。如果占位圖(placeHolder)比請(qǐng)求加載的url圖要大,或者實(shí)際加載圖是有透明部分未把占位圖遮擋,就會(huì)看到占位圖,占位圖被當(dāng)作加載成功后的圖的背景展示,遇到此問(wèn)題在glide官網(wǎng)查到了此問(wèn)題,github上也有這個(gè)issiue,官網(wǎng)給出的對(duì)應(yīng)的解決方案如下:

image.png

官網(wǎng)并沒(méi)有明確指出具體改如何使用,本人在網(wǎng)上搜了各種資料也未找到具體實(shí)現(xiàn)。在看了DrawableCrossFadeFactory的源碼后本人找到了答案,示例代碼如下:

DrawableCrossFadeFactory drawableCrossFadeFactory = new DrawableCrossFadeFactory.Builder(300).setCrossFadeEnabled(true).build();
Glide.with(this)
    .load(URL_JPG)
    .apply(new RequestOptions().placeholder(R.drawable.ic_launcher))
    .transition(DrawableTransitionOptions.with(drawableCrossFadeFactory))
    .into(imageView);

相信此問(wèn)題,應(yīng)該會(huì)有不少小伙伴遇到,貼出來(lái)供大家參考。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容