您好,登錄后才能下訂單哦!
當ViewPager切換到當前的Fragment時,F(xiàn)ragment會加載布局并顯示內(nèi)容,如果用戶這時快速切換ViewPager,即Fragment需要加載UI內(nèi)容,而又頻繁地切換Fragment,就容易產(chǎn)生卡頓現(xiàn)象(類似在ListView快速滑動的同時加載圖片容易卡頓)。
優(yōu)化方案:
1.Fragment輕量化
如果ViewPager加載的Fragment都比較輕量,適當精簡Fragment的布局,可提高Fragment加載的速度,從而減緩卡頓現(xiàn)象。
2.防止Fragment被銷毀
ViewPager在切換的時候,如果頻繁銷毀和加載Fragment,就容易產(chǎn)生卡頓現(xiàn)象,阻止Fragment的銷毀可有效減緩卡頓現(xiàn)象。
(1)在PagerAdapter里覆蓋destroyItem方法可阻止銷毀Fragment
@Override public void destroyItem(ViewGroup container, int position, Object object) { //super.destroyItem(container, position, object); }
(2)通過PagerAdapter的setOffscreenPageLimit()方法可以設(shè)置保留幾個Fragment,適當增大參數(shù)可防止Fragment頻繁地被銷毀和創(chuàng)建。
風險:在Fragment比較多的情況下,部分低端機型容易產(chǎn)生OOM問題。
3.Fragment內(nèi)容延遲加載
(1) 描述
在切換到當前Fragment的時候,并不立刻去加載Fragment的內(nèi)容,而是先加載一個簡單的空布局,然后啟動一個延時任務(wù),延時時長為T,當用戶在該Fragment停留時間超過T時,繼續(xù)執(zhí)行加載任務(wù);而當用戶切換到其他Fragment,停留時間低于T,則取消該延時任務(wù)。
(2) 具體操作
首先,設(shè)置延遲任務(wù)
private Runnable LOAD_DATA = new Runnable() { @Override public void run() { //在這里數(shù)據(jù)內(nèi)容加載到Fragment上 } };
啟動任務(wù)
@Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { //初始化視圖,這里最好先設(shè)置一個進度對話框,提示用戶正在加載數(shù)據(jù) initView(); //啟動任務(wù),這里設(shè)置500毫秒后開始加載數(shù)據(jù) handler.postDelayed(LOAD_DATA,500) return view; }
若用戶切換到其他Fragment則取消任務(wù)
//判斷Fragment是否可視的重載方法 @Override public void setUserVisibleHint(boolean isVisibleToUser) { super.setUserVisibleHint(isVisibleToUser); if(!isVisibleToUser) mHandler.removeCallbacks(LOAD_DATA); }
(3) 注意
使用setUserVisibleHint判斷用戶是否切換到其他Fragment,這樣的做法有個缺陷,因為會在ViewPager開始滑動的時候取消延時任務(wù),而在滑動偏移量不足的情況下,ViewPager會繼續(xù)回滾到當前Fragment,導致當前Fragment的加載任務(wù)被取消而又不會重新啟動加載任務(wù)。
這里我使用的做法是,給ViewPager增加一個OnPageChangeListener,,該監(jiān)聽器的onPageSelected(position)能監(jiān)聽ViewPager當前切換到哪個Fragment,在這里將其他Fragment的延遲加載任務(wù)取消掉。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。