记得最初使用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);
}
}
};
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。