当前位置:首页 > 科技  > 软件

ViewPager如何通过预加载机制提高滑动性能,以及如何屏蔽预加载策略的方法

来源: 责编: 时间:2024-06-17 08:44:37 68观看
导读ViewPager默认具有预加载机制,会预先加载当前页面前后的一定数量的页面,以便在滑动时能够迅速显示新页面。预加载的数量可以通过setOffscreenPageLimit(int limit)方法来设置,但最小值通常为1,意味着前后各预加载一个页面

ViewPager默认具有预加载机制,会预先加载当前页面前后的一定数量的页面,以便在滑动时能够迅速显示新页面。预加载的数量可以通过setOffscreenPageLimit(int limit)方法来设置,但最小值通常为1,意味着前后各预加载一个页面。xZL28资讯网——每日最新资讯28at.com

public void setOffscreenPageLimit(int limit) {    if (limit < 1) {        Log.w("ViewPager", "Requested offscreen page limit " + limit + " too small; defaulting to " + 1);        limit = 1;    }    if (limit != this.mOffscreenPageLimit) {        this.mOffscreenPageLimit = limit;        this.populate();    }}

下面看看预加载的是什么,在预加载数量更新的时候,执行polulate()方法。xZL28资讯网——每日最新资讯28at.com

void populate(int newCurrentItem) {    ViewPager.ItemInfo oldCurInfo = null;    if (this.mCurItem != newCurrentItem) {        oldCurInfo = this.infoForPosition(this.mCurItem);        this.mCurItem = newCurrentItem;    }    if (this.mAdapter == null) {        this.sortChildDrawingOrder();    } else if (this.mPopulatePending) {        this.sortChildDrawingOrder();    } else if (this.getWindowToken() != null) {        this.mAdapter.startUpdate(this);//被弃用了        int pageLimit = this.mOffscreenPageLimit;//当前的缓存页面个数        int startPos = Math.max(0, this.mCurItem - pageLimit);//计算缓存的开始位置        int N = this.mAdapter.getCount();//adapter的子内容的数量        int endPos = Math.min(N - 1, this.mCurItem + pageLimit);//计算缓存的结束位置        if (N != this.mExpectedAdapterCount) {            String resName;            try {                resName = this.getResources().getResourceName(this.getId());            } catch (NotFoundException var17) {                resName = Integer.toHexString(this.getId());            }            throw new IllegalStateException("The application's PagerAdapter changed the adapter's contents without calling PagerAdapter#notifyDataSetChanged! Expected adapter item count: " + this.mExpectedAdapterCount + ", found: " + N + " Pager id: " + resName + " Pager class: " + this.getClass() + " Problematic adapter: " + this.mAdapter.getClass());        } else {            int curIndex = true;            ViewPager.ItemInfo curItem = null;            //开始去找 ViewPager.ItemInfo            int curIndex;            for(curIndex = 0; curIndex < this.mItems.size(); ++curIndex) {                ViewPager.ItemInfo ii = (ViewPager.ItemInfo)this.mItems.get(curIndex);                if (ii.position >= this.mCurItem) {                    if (ii.position == this.mCurItem) {                        curItem = ii;                    }                    break;                }            }            //没找到就去创建 ViewPager.ItemInfo,并放入ArrayList<ViewPager.ItemInfo> mItems中            if (curItem == null && N > 0) {                curItem = this.addNewItem(this.mCurItem, curIndex);            }            int itemIndex;            ViewPager.ItemInfo ii;            int i;            ·····一些计算操作,省略        }                    this.mAdapter.finishUpdate(this);//完成条目的更新        int childCount = this.getChildCount();        for(itemIndex = 0; itemIndex < childCount; ++itemIndex) {            View child = this.getChildAt(itemIndex);            ViewPager.LayoutParams lp = (ViewPager.LayoutParams)child.getLayoutParams();            lp.childIndex = itemIndex;            if (!lp.isDecor && lp.widthFactor == 0.0F) {                ViewPager.ItemInfo ii = this.infoForChild(child);                if (ii != null) {                    lp.widthFactor = ii.widthFactor;                    lp.position = ii.position;                }            }        }        this.sortChildDrawingOrder();    }}

ViewPager通过计算当前页面的索引(mCurItem)和预加载页面的限制数量(mOffscreenPageLimit或pageLimit)来确定需要预加载的页面范围。通过Math.max(0, mCurItem - pageLimit)计算预加载的起始页面索引(startPos),通过Math.min(N-1, mCurItem + pageLimit)计算预加载的结束页面索引(endPos),N是页面总数。在这个范围内,ViewPager会提前加载并创建页面实例,以减少用户滑动到这些页面时的加载时间。xZL28资讯网——每日最新资讯28at.com

xZL28资讯网——每日最新资讯28at.com

当ViewPager的当前页面改变时,会根据新的当前页面索引和预加载范围来加载或销毁页面实例。如果某个页面实例不再处于预加载范围内,它将被销毁以释放内存。xZL28资讯网——每日最新资讯28at.com

ViewPager.ItemInfo addNewItem(int position, int index) {    ViewPager.ItemInfo ii = new ViewPager.ItemInfo();    ii.position = position;        ii.object = this.mAdapter.instantiateItem(this, position);    ii.widthFactor = this.mAdapter.getPageWidth(position);    if (index >= 0 && index < this.mItems.size()) {        this.mItems.add(index, ii);    } else {        this.mItems.add(ii);    }    return ii;}

调用instantiateItem来创建object,在FragmentPagerAdapter的instantiateItem这个方法中,创建的是Fragment,即缓存的就是Fragment,Fragment在创建时,会有UI操作,网络操作,在还未可见的时候初始化Fragment非常消耗性能,所以应该懒加载的方式来加载,不去缓存Fragment。xZL28资讯网——每日最新资讯28at.com

ViewPager屏蔽预加载方式:xZL28资讯网——每日最新资讯28at.com

  1. 「设置setOffscreenPageLimit(int limit)方法的limit为0」:

理论上,这是最直接的方法,实际上setOffscreenPageLimit(int limit)方法中的limit值有一个最小值限制,即使你设置为0,也会自动调整为1。因为ViewPager的设计初衷就是为了预加载相邻的页面以提高滑动性能。xZL28资讯网——每日最新资讯28at.com

  1. 「自定义ViewPager」:

「方法一」:复制ViewPager的源代码,并修改DEFAULT_OFFSCREEN_PAGES常量的值为0。xZL28资讯网——每日最新资讯28at.com

「方法二」:继承ViewPager类,重写setOffscreenPageLimit(int limit)方法,利用反射修改mOffscreenPageLimit属性的值。这种方法可能涉及到对Android系统内部实现的深入了解,并且可能随着Android版本的更新而失效。xZL28资讯网——每日最新资讯28at.com

  1. xZL28资讯网——每日最新资讯28at.com

    「调整PagerAdapter」:xZL28资讯网——每日最新资讯28at.com

    xZL28资讯网——每日最新资讯28at.com

可以通过调整PagerAdapter中的instantiateItem和destroyItem方法来控制页面的加载和销毁。例如,可以在这些方法中实现更精细的页面管理策略,以减少不必要的资源消耗。xZL28资讯网——每日最新资讯28at.com

  1. xZL28资讯网——每日最新资讯28at.com

    「懒加载技术」:xZL28资讯网——每日最新资讯28at.com

    xZL28资讯网——每日最新资讯28at.com

在Fragment或页面内容中使用懒加载技术。页面只有在真正需要显示时才会被加载。这可以通过在Fragment的setUserVisibleHint(boolean isVisibleToUser)方法中判断页面是否可见来实现。xZL28资讯网——每日最新资讯28at.com

  1. xZL28资讯网——每日最新资讯28at.com

    「注意事项」:xZL28资讯网——每日最新资讯28at.com

    xZL28资讯网——每日最新资讯28at.com

屏蔽预加载可能会影响ViewPager的滑动性能,当用户滑动到新的页面时,该页面可能需要花费更长的时间来加载。xZL28资讯网——每日最新资讯28at.com

在决定屏蔽预加载之前,权衡好性能和资源消耗之间的平衡。xZL28资讯网——每日最新资讯28at.com

xZL28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-94136-0.htmlViewPager如何通过预加载机制提高滑动性能,以及如何屏蔽预加载策略的方法

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 发给马斯克 560 亿美元,特斯拉为什么还涨了

下一篇: 15个超好看的登录页面(附源码)

标签:
  • 热门焦点
  • Flowable工作流引擎的科普与实践

    Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 让我们一起聊聊文件的操作

    让我们一起聊聊文件的操作

    文件【1】文件是什么?文件是保存数据的地方,是数据源的一种,比如大家经常使用的word文档、txt文件、excel文件、jpg文件...都是文件。文件最主要的作用就是保存数据,它既可以保
  • 一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    作者:Hiu 来源:互联网品牌官01 擦边少女空降热搜,幕后推手曝光被网友誉为&ldquo;纯欲天花板&rdquo;的女网红井川里予,近期因为一组哥特风照片登上热搜,引发了一场互联网世界关于
  • 8月见!小米MIX Fold 3获得3C认证:支持67W快充

    8月见!小米MIX Fold 3获得3C认证:支持67W快充

    这段时间以来,包括三星、一加、荣耀等等有不少品牌旗下的最新折叠屏旗舰都得到了不少爆料,而小米新一代折叠屏旗舰——小米MIX Fold 3此前也屡屡被传
  • 华为开发者大会2023日程公开:开设鸿蒙HarmonyOS 4体验区

    华为开发者大会2023日程公开:开设鸿蒙HarmonyOS 4体验区

    IT之家 7 月 31 日消息,华为今日公布了 HDC.Together 开发者大会 2023 的详细日程。整场大会将于 8 月 4 日-6 日之间举行,届时将发布最新一代鸿蒙 H
  • Android 14发布:首批适配机型公布

    Android 14发布:首批适配机型公布

    5月11日消息,谷歌在今天凌晨举行了I/O大会,本次发布会谷歌带来了自家的AI语言模型PaLM 2、谷歌Pixel Fold折叠屏、谷歌Pixel 7a手机,同时发布了Androi
  • 电博会上海尔智家模拟500平大平层,还原生活空间沉浸式体验

    电博会上海尔智家模拟500平大平层,还原生活空间沉浸式体验

    电博会为了更好地让参展观众真正感受到智能家居的绝妙之处,海尔智家的程传岭先生同样介绍了展会上海尔智家的模拟500平大平层,还原生活空间沉浸式体验。程传
  • 利用职权私自解除被封帐号 Meta开除20多名员工

    利用职权私自解除被封帐号 Meta开除20多名员工

    11月18日消息,据外媒援引知情人士表示,过去一年时间内,Facebook母公司Meta解雇或处罚了20多名员工以及合同工,指控这些人通过内部系统以不当方式重置用户帐号,其
  • 北京:科技教育体验基地开始登记

    北京:科技教育体验基地开始登记

      北京“科技馆之城”科技教育体验基地登记和认证工作日前启动。首批北京科技教育体验基地拟于2023年全国科普日期间挂牌,后续还将开展常态化登记。  北京科技教育体验基
Top