viewpager之自动滑动(ScheduledExecutorService的使用)

以前一直没有时间去研究viewpager的自动滑动,每次都是去网上找,各种例子都有,最近终于闲下来,决定自己研究下,直接使用的ScheduledExecutorService,其余的不解释,我就是喜欢用这个,我就是觉得他好用,没有为什么,其他的也不考虑

直接上代码

package com.demo.neu.xianzhi.activity;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;

import com.demo.neu.R;
import com.demo.neu.xianzhi.adapter.ViewPagerAdapter;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

/**
 * Created by 李博 on 2016/10/20.
 */
public class ViewPagerAcivity extends Activity {

    //下标
    private int currentItem = 0;
    //图片集合
    private List<View> images;
    //适配器
    private ViewPagerAdapter adapter;
    //点集合
    private List<View> dots;

    private ScheduledExecutorService scheduledExecutorService;

    private ViewPager mViewpager;

    private View view;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        view = LayoutInflater.from(this).inflate(R.layout.home_layout, null);
        setContentView(view);
        initView();
        setPageChangeListener();
    }

    protected void initView() {

        mViewpager = (ViewPager) view.findViewById(R.id.mViewPager);

        dots = new ArrayList<>();
        images = new ArrayList<>();
        dots.add(view.findViewById(R.id.home_iv_dian1));
        dots.add(view.findViewById(R.id.home_iv_dian2));
        dots.add(view.findViewById(R.id.home_iv_dian3));
        dots.add(view.findViewById(R.id.home_iv_dian4));
        setViewPagerDatas();
        adapter = new ViewPagerAdapter(images, this);
        mViewpager.setAdapter(adapter);


    }

    /**
     * 获取viewpager的数据
     */
    private void setViewPagerDatas() {

    }

    /**
     * viewpager的滑动监听
     */
    private void setPageChangeListener() {
        mViewpager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            int oldPosition = 0;

            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
                currentItem = position;
                dots.get(oldPosition).setBackgroundResource(R.mipmap.home_dian2);
                dots.get(position).setBackgroundResource(R.mipmap.home_dian1);
                oldPosition = position;
            }

            @Override
            public void onPageSelected(int position) {

            }

            @Override
            public void onPageScrollStateChanged(int state) {

            }
        });
    }

    @Override
    public void onStart() {
        super.onStart();
        //建立一个单独的线程
        scheduledExecutorService = Executors.newSingleThreadScheduledExecutor();
        /**
         * 声明一个线程   设置5S之后切换图片
         *  执行线程
         *  初始化延时
         *  两次开始执行最小间隔时间
         *  计时单位
         */
        scheduledExecutorService.scheduleAtFixedRate(
                new ScrollTask(),
                0,
                5,
                TimeUnit.SECONDS);
    }

    @Override
    public void onStop() {
        scheduledExecutorService.shutdown();
        super.onStop();
    }

    //滑动线程
    private Handler handler = new Handler() {
        @Override
        public void handleMessage(Message msg) {
            super.handleMessage(msg);
            //是否有滑动动画   true有滑动动画  默认是true
            mViewpager.setCurrentItem(currentItem, false);
        }
    };

    private class ScrollTask implements Runnable {

        @Override
        public void run() {
            currentItem = (currentItem + 1) % images.size();
            handler.obtainMessage().sendToTarget();
        }
    }

}

适配器

package com.demo.neu.xianzhi.adapter;

import android.content.Context;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;

import java.util.List;

/**
 * Created by 李博 on 2016/9/29.
 */
public class ViewPagerAdapter extends PagerAdapter {

    private List<View> images;
    private Context context;

    public ViewPagerAdapter(List<View> images, Context context) {
        this.images = images;
        this.context = context;
    }

    @Override
    public int getCount() {
        return images.size();
    }

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

    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        container.addView(images.get(position), 0);
        return images.get(position);
    }

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

}
就这些,不明白的可以留言,至于解释嘛,注释已经写的很明白了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现ViewPager的自动滑动和手动滑动加点击切换,可以按以下步骤进行操作: 1. 在layout文件中添加ViewPager控件: ``` <android.support.v4.view.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="wrap_content"/> ``` 2. 在Activity或Fragment中初始化ViewPager并设置Adapter: ``` ViewPager viewPager = findViewById(R.id.view_pager); viewPager.setAdapter(new MyPagerAdapter(getSupportFragmentManager())); ``` 3. 实现自动滑动功能,可以使用Handler和Runnable来实现: ``` private Handler handler = new Handler(); private Runnable runnable = new Runnable() { @Override public void run() { int currentItem = viewPager.getCurrentItem(); int count = viewPager.getAdapter().getCount(); if (currentItem < count - 1) { viewPager.setCurrentItem(currentItem + 1); } else { viewPager.setCurrentItem(0); } handler.postDelayed(runnable, 3000); } }; // 在onResume()方法中启动自动滑动 @Override protected void onResume() { super.onResume(); handler.postDelayed(runnable, 3000); } // 在onPause()方法中停止自动滑动 @Override protected void onPause() { super.onPause(); handler.removeCallbacks(runnable); } ``` 4. 实现手动滑动和点击切换功能,可以在ViewPager的OnPageChangeListener中处理: ``` viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {} @Override public void onPageSelected(int position) { // 处理页面切换事件 } @Override public void onPageScrollStateChanged(int state) { // 处理滑动状态变化事件 } }); ``` 在onPageSelected()方法中可以处理页面切换事件,比如更新页面指示器的状态。在onPageScrollStateChanged()方法中可以处理滑动状态变化事件,比如停止自动滑动或重新开始自动滑动。 以上就是实现ViewPager自动滑动和手动滑动加点击切换的基本步骤,具体实现可以根据需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值