ViewPager+Handler实现图片自动轮播的效果

效果图就不贴了,最下面有源码,用AndroidStudio写的。

分析来也就两种状态,暂停轮播和开始轮播,这里为了避免bug,有一个记录页号的TAG

布局是最简单的。只有一个viewpager,在V4包下面




<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.view.ViewPager xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/ViewPager_vp"
android:layout_width="match_parent"
android:layout_height="match_parent">

</android.support.v4.view.ViewPager>
简单的activity

package demo.viewpager;

import android.os.Bundle;
import android.os.Message;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;

import demo.viewpager.Utils.ViewPagerHandlerUtils;
import demo.viewpager.adapter.ViewPagerAdapter;

/**
 * Created by 12406 on 2016/1/16.
 */
public class ViewPagerActivity extends AppCompatActivity {


    private ViewPagerAdapter adapter;
    private ViewPager viewPager;
    private ViewPagerHandlerUtils handlerUtils;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_viewpager);
        viewPager = (ViewPager) findViewById(R.id.ViewPager_vp);

        init();
    }

    private void init() {
        handlerUtils = new ViewPagerHandlerUtils(viewPager);
        handlerUtils.sendEmptyMessageDelayed(handlerUtils.MSG_UPDATE, handlerUtils.MSG_DELAY);
        adapter = new ViewPagerAdapter(this);
        viewPager.setAdapter(adapter);
        viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
            }

            @Override
            public void onPageSelected(int position) {
                handlerUtils.sendMessage(Message.obtain(handlerUtils, handlerUtils.MSG_PAGE, position, 0));
            }

            @Override
            public void onPageScrollStateChanged(int state) {
                switch (state) {
                    case ViewPager.SCROLL_STATE_DRAGGING:
                        handlerUtils.sendEmptyMessage(handlerUtils.MSG_KEEP);
                        break;
                    case ViewPager.SCROLL_STATE_IDLE:
                        handlerUtils.sendEmptyMessageDelayed(handlerUtils.MSG_UPDATE,
                                handlerUtils.MSG_DELAY);
                }
            }
        });
    }
}

Adapter也是单独写的一个java类

package demo.viewpager.adapter;

import android.app.Activity;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.Toast;

import demo.viewpager.R;

/**
 * Created by 12406 on 2016/1/16.
 */
public class ViewPagerAdapter extends PagerAdapter {
    private Activity activity;
    private int[] imager = new int[]{R.drawable.item1, R.drawable.item2, R.drawable.item3, R.drawable.item4, R.drawable.item5, R.drawable.item6};


    public ViewPagerAdapter(Activity activity) {
        this.activity = activity;
    }


    @Override
    public int getCount() {
        return Integer.MAX_VALUE;
    }

    @Override
    public boolean isViewFromObject(View view, Object object) {
        return view == object;
    }

    @Override
    public void destroyItem(ViewGroup container, int position,
                            Object object) {
        container.removeView((View) object);
    }

    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        position %= imager.length;
        if (position < 0) {
            position = imager.length + position;
        }
        ImageView imageView = new ImageView(activity);
        imageView.setImageResource(imager[position]);
//        imageView.setScaleType(ImageView.ScaleType.FIT_XY);
        final int finalPosition = position;
        imageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(activity, "第" + finalPosition + "个被点击了", Toast.LENGTH_SHORT).show();
            }
        });
        container.addView(imageView);
        return imageView;
    }


}


Handler为了方便直接抽取出来写一个工具类

package demo.viewpager.Utils;


import android.os.Handler;
import android.os.Message;
import android.support.v4.view.ViewPager;

public class ViewPagerHandlerUtils extends Handler {

    /**
     * 请求更新显示的ImageView。
     */
    public static final int MSG_UPDATE = 1;
    /**
     * 请求暂停轮播。
     */
    public static final int MSG_KEEP = 2;
    /**
     * 请求恢复轮播。
     */
    public static final int MSG_BREAK = 3;
    /**
     * 记录最新的页号
     */
    public static final int MSG_PAGE = 4;

    //轮播间隔时间
    public static final long MSG_DELAY = 2000;

    private ViewPager mViewPager;
    private int currentItem = 0;

    public ViewPagerHandlerUtils(ViewPager viewPager) {
        mViewPager = viewPager;
    }

    @Override
    public void handleMessage(Message msg) {
        super.handleMessage(msg);
        if (mViewPager == null) {
            return;
        }
        if (hasMessages(MSG_UPDATE)) {
            removeMessages(MSG_UPDATE);
        }
        switch (msg.what) {
            case MSG_UPDATE:
                currentItem++;
                mViewPager.setCurrentItem(currentItem);
                sendEmptyMessageDelayed(MSG_UPDATE, MSG_DELAY);
                break;
            case MSG_KEEP:
                break;
            case MSG_BREAK:
                sendEmptyMessageDelayed(MSG_UPDATE, MSG_DELAY);
                break;
            case MSG_PAGE:
                currentItem = msg.arg1;
                break;
            default:
                sendEmptyMessageDelayed(MSG_UPDATE, MSG_DELAY);
                break;
        }
    }
}

代码也是最基础的一些东西,看起来也不费劲。

点击下载源码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值