androidviewpage左右无限轮播

发现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);
    }
}

猜你喜欢

转载自blog.csdn.net/qq_24543821/article/details/88073669