发现viewpager无限轮播大多数都是把Adapter的getCount()方法返回Integer.MAX_VALUE;这样虽然可以实现向右无限滑动,但是向左不行,第二个就是这样做也太骚了,如果不是现在大多数图片加载框架都有缓存,那得浪费多少流量,第三又不能设置缓存,最重要的是要浪费多少性能。其实只要多加两个实例就完全可以实现左右的无限轮播,没错,getCount()返回list.size()+2就行了
其原理如图,假如数据只有三条,增加两个实例,最开始显示位置1的item,当向左滑滑到位置0时,自动滑动到位置3(无动画滑动),同理向右滑动到位置4时,自动滑到位置1.
vpBanner.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
private int vpPosition;
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
vpPosition = position;
}
@Override
public void onPageScrollStateChanged(int state) {
if (state == ViewPager.SCREEN_STATE_OFF){
if (vpPosition == 0){
vpBanner.setCurrentItem(mListSize,false);
}else if (vpPosition == mListSize + 1){
vpBanner.setCurrentItem(1,false);
}
}
}
});
至于为什么不是在onPageSelected()方法做切换操作,你试一下就知道了,把切换写在onPageSelected()里每次到边缘的时候都会有一点不流畅,原因是onPageSelected()只要你滑动的距离超过了一半松手后就马上回调,所以就会有一闪的感觉,所以我们要等滑动完成后才去切换
import android.content.Context;
import android.support.annotation.NonNull;
import android.support.v4.view.PagerAdapter;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import java.util.List;
public class ViewPageAdapter extends PagerAdapter {
private Context mContext;
private List<Integer>listImg ;
public ViewPageAdapter(Context mContext, List<Integer> listImg) {
this.mContext = mContext;
this.listImg = listImg;
}
@Override
public int getCount() {
return listImg.size() + 2;
}
@Override
public boolean isViewFromObject(@NonNull View view, @NonNull Object object) {
return view == object;
}
@NonNull
@Override
public Object instantiateItem(@NonNull ViewGroup container, int position) {
View view = LayoutInflater.from(mContext).inflate( R.layout.item_banner,null,false);
ImageView ivBanner = view.findViewById(R.id.ivBanner);
if (position == 0){
ivBanner.setImageResource(listImg.get(listImg.size() - 1).intValue());
}else if(position == listImg.size()+1){
ivBanner.setImageResource(listImg.get(0).intValue());
}else{
ivBanner.setImageResource(listImg.get(position - 1).intValue());
}
container.addView(view);
return view;
}
@Override
public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
container.removeView((View) object);
}
}