ViewPager实现无限循环的2种方法

项目中有一处banner循环滚动,近期发现在某机型上快速滑动会有一点点问题(还是配置很高级的机型)。于是换了一种实现方式。


以ViewPager中有3个Item为例。它的排列如下:


先第一种方式的思路,是在首尾各加一张图片。使其排列如下:



然后滑到首尾2张图片(外层的2和0)时给它悄悄回到对应的位置(内层的0和2)

处理如下:

mViewPager.setAdapter(viewPagerAdapter);
        mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

            }

            @Override
            public void onPageSelected(int position) {
                if(viewPagerAdapter.getCount() <= 1)
                    return;
                if(position == viewPagerAdapter.getCount()-1){
                    mViewPager.setCurrentItem(1, false);
                }else if(position == 0){
                    mViewPager.setCurrentItem(viewPagerAdapter.getCount()-2, false);
                }
            }

            @Override
            public void onPageScrollStateChanged(int state) {

            }
        });



第二种方式,是不设置ViewPager的边界,使其拥有超多个选项卡(Integer.MAX_VALUE),然后将初始位置设置在中间。


只需要修改PagerAdapter的getCount方法

   @Override
    public int getCount() {
        if(pageItems.size()==1){
            return 1;
        }
        return Integer.MAX_VALUE;
    }
但在setCurrentItem()的时候,发现可能有发生ANR,发生ANR的地方是下面的else中。

if (mFirstLayout) {
            // We don't have any idea how big we are yet and shouldn't have any pages either.
            // Just set things up and let the pending layout handle things.
            mCurItem = item;
            if (dispatchSelected) {
                dispatchOnPageSelected(item);
            }
            requestLayout();
        } else {
            populate(item);
            scrollToItem(item, smoothScroll, velocity, dispatchSelected);
        }
原因是,ViewPager初始化完成后,再调setCurrentItem,ViewPager会一个一个页卡滑过去,直到滑到指定的页卡。

因此还需要重写ViewPager的setCurrentItem方法。

    @Override
    public void setCurrentItem(int item) {
        if (Math.abs(item-getCurrentItem()) > 3){
            setFirstLayout();
        }
        super.setCurrentItem(item);
    }

    @Override
    public void setCurrentItem(int item, boolean smoothScroll) {
        if (Math.abs(item-getCurrentItem()) > 3){
            setFirstLayout();
        }
        super.setCurrentItem(item, smoothScroll);
    }
    
    private void setFirstLayout(){
        try {
            Field mFirstLayout = ViewPager.class.getDeclaredField("mFirstLayout");
            mFirstLayout.setAccessible(true);
            mFirstLayout.set(this, true);
        }catch(Exception e) {
            e.printStackTrace();
        }
    }




  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现ViewPager中Fragment的无限循环,可以采用以下几个步骤: 1.在ViewPager的Adapter中重写getCount()方法,将其返回一个较大的值,例如Integer.MAX_VALUE,这样就可以让ViewPager中的Fragment无限循环。 2.在ViewPager的Adapter中重写getItem()方法,将其返回的position取模操作,以确保获取到正确的Fragment。 3.在ViewPager的Adapter中重写getPageTitle()方法,将其返回的title也进行取模操作,以确保获取到正确的title。 下面是一个示例代码: ```java public class MyPagerAdapter extends FragmentPagerAdapter { private static final int NUM_PAGES = 3; private List<Fragment> fragmentList; private List<String> titleList; public MyPagerAdapter(FragmentManager fm) { super(fm); fragmentList = new ArrayList<>(); titleList = new ArrayList<>(); for (int i = 0; i < NUM_PAGES; i++) { fragmentList.add(new MyFragment()); titleList.add("Page " + (i + 1)); } } @Override public Fragment getItem(int position) { return fragmentList.get(position % NUM_PAGES); } @Override public int getCount() { return Integer.MAX_VALUE; } @Override public CharSequence getPageTitle(int position) { return titleList.get(position % NUM_PAGES); } } ``` 在上面的示例代码中,我们将ViewPager中的Fragment数量设置为3,然后在getCount()方法中返回一个较大的值Integer.MAX_VALUE,这样就可以让ViewPager中的Fragment无限循环。在getItem()和getPageTitle()方法中,我们对position取模操作,以确保获取到正确的Fragment和title。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值