记得最初使用ViewPager实现无限轮播大致是这样的.

 class BannerPagerAdapter extends PagerAdapter {
        List<View> list;
        @Override
        public int getCount() {           
            return Integer.MAX_VALUE;
        }
        @Override
        public Object instantiateItem(ViewGroup container, final int position) {
            int realPosition = position%list.size();
            return list.get(realPosition);
        }
    }

在使用了开源库Banner后,感觉这个库处理无限轮播,写的非常好.

这个库可以左右无限滑动,也可以自动左右无限轮播.

首先先了解下,其大致原理.

在数据的前后两端各添加一条数据.前端添加的是最后一天数据,尾端添加的是第一条数据.如图:
图片描述

当从C滑动到D时,在ViewPager.OnPageChangeListener#onPageScrollStateChanged()中做监听并快速切换到A;
当从A滑动到E时,在ViewPager.OnPageChangeListener#onPageScrollStateChanged()中做监听并快速切换到C;
这里切换使用viewPager.setCurrentItem(int,boolean);第二个参数为false,表示不使用动画,直接快速切换,造成一种无限轮播的假象.

然后在ViewPager.OnPageChangeListener中做监听处理并快速切换.

//当前页面索引
int currentIndex  = 1;
//数据源的实际大小
int pageCount;
 private ViewPager.OnPageChangeListener onPageChangeListener = new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

        }

        @Override
        public void onPageSelected(int position) {
            currentIndex = position;
        }

        @Override
        public void onPageScrollStateChanged(int state) {
                //在这里做快速切换,当你滑动到首位,要快速切换到尾端
               if (currentIndex==0){
                   viewPager.setCurrentItem(pageCount,false);
               }
               //当你滑动到尾端,要快速切换到首位
               if (currentIndex==pageCount+1){
                   viewPager.setCurrentItem(1,false);
               }       
        }
    };

idealcn
27 声望4 粉丝