记得最初使用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); } } };