共计 1217 个字符,预计需要花费 4 分钟才能阅读完成。
记得最初使用 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);
}
}
};