高效的图片轮播

最近在做写知乎日报,用到图片轮播,看到比较普遍的方法是把getcount设得很大。这种方法明显是不够高效的。后来看到前辈@Krelve的一篇博客,大赞。这里做详细讲解下。这里写图片描述
原理就是,在最后一张图片的后面,加多一张和第一张一样的图片。当轮播到最后一张时(也就是和第一张一样的图片),在OnPageChangeListener的onPageScrollStateChanged方法中将图片无动画地设为第一张。

1、初始化数据,i==0和i==5设置同一张图片
private void initData() {
viewList = new ArrayList();
for (int i = 0; i <= 4 + 1; i++) {
View item = LayoutInflater.from(this).inflate(R.layout.item, null);
ImageView imageView = (ImageView) item.findViewById(R.id.image_view);

        if (i == 0) {
            imageView.setImageResource(R.drawable.item1);
        } else if (i == 5) {
            //本身5张图,在第六张图的位置,再添加第一张图
            imageView.setImageResource(R.drawable.item1);
        } else if (i == 1) {
            imageView.setImageResource(R.drawable.item2);
        } else if (i == 2) {
            imageView.setImageResource(R.drawable.item3);
        } else if (i == 3) {
            imageView.setImageResource(R.drawable.item4);

        } else if (i == 4) {
            imageView.setImageResource(R.drawable.item5);
        }
        viewList.add(item);
    }

    MyAdapter myAdapter = new MyAdapter(viewList);
    mViewPager.setAdapter(myAdapter);
    mViewPager.setCurrentItem(0);
    mViewPager.addOnPageChangeListener(new MyOnPageChangeListener());
    current_item = 0;
}

2、viewpager滑动监听,onPageScrollStateChanged的arg0参数:arg0 ==1–默示正在滑动,arg0==2–默示滑动完毕了,arg0==0–默示什么都没做。判断i==5时,将它无动画地切换到i==0

class MyOnPageChangeListener implements ViewPager.OnPageChangeListener {

    /**
     * arg0这个参数有三种状态(0,1,2)。arg0 ==1--默示正在滑动,arg0==2--默示滑动完毕了,arg0==0--默示什么都没做。
     *
     * @param arg0
     */
    @Override
    public void onPageScrollStateChanged(int arg0) {
        switch (arg0) {
            case 1:
                isAutoPlay = false;
                break;
            case 2:
                isAutoPlay = true;
                break;
            case 0:
                if (mViewPager.getCurrentItem() == 4 + 1) {
                    /**
                     * false表示无动画效果调到指定页。
                     * 由于最后一页和第一页的图片是一样的,无动画跳转给人的感觉就是已经是第一页
                     */
                    mViewPager.setCurrentItem(0, false);
                }
                current_item = mViewPager.getCurrentItem();
                isAutoPlay = true;
                break;
        }
    }

    @Override
    public void onPageScrolled(int arg0, float arg1, int arg2) {
    }

    @Override
    public void onPageSelected(int arg0) {
    }
}

3、通过handler.postDelayed(task, 1500);方法实现定时切换

private void startPlay() {
isAutoPlay = true;
handler.postDelayed(task, 1500);
}

private Runnable task = new Runnable() {
    @Override
    public void run() {
        current_item = current_item % 6 + 1;
        if (isAutoPlay) {
            if (current_item == 0) {
                mViewPager.setCurrentItem(current_item, false);
                handler.postDelayed(task, 1500);
            } else {
                mViewPager.setCurrentItem(current_item);
                handler.postDelayed(task, 1500);
            }
        } else {
            handler.postDelayed(task, 1500);
        }
    }
};

源码地址:http://download.csdn.net/detail/qq_24334367/9616116

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值