Android App中用Handler实现ViewPager页面的自动切换

Android App中用Handler实现ViewPager页面的自动切换,第1张

概述在很多电商网页及app上都有自动切换的商品的推广快,感觉体验挺不错的,正好今天学习使用ViewPager,因此也实现了一个功能类似的demo。

在很多电商网页及app上都有自动切换的商品的推广快,感觉体验挺不错的,正好今天学习使用VIEwPager,因此也实现了一个功能类似的demo。

下面是其中的两个截图:

实现一个自动播放功能的VIEwPager,要做的主要有以下的几个部分:

实现一个VIEwPagerAdapter,用于为VIEwPager提供展示内容(例如上面的两张小猫图片)

 public class VIEwPagerAdapter extends PagerAdapter {    private List<VIEw> mData;    public VIEwPagerAdapter(List<VIEw> mData) {      this.mData = mData;    }    @OverrIDe    public int getCount() {      return mData.size();    }    @OverrIDe    public boolean isVIEwFromObject(VIEw arg0,Object arg1) {      return arg0 == arg1;    }        @OverrIDe    public Object instantiateItem(VIEwGroup container,int position) {      VIEw v = mData.get(position);      container.addVIEw(v);      return v;    }        @OverrIDe    public voID destroyItem(VIEwGroup container,int position,Object object) {//  super.destroyItem(container,position,object);      container.removeVIEw(mData.get(position));    }      }

实现一个OnPagechangelistener,这样在页面切换后可以提示当前页面所在的位置(例如上图中,左下角的3个圆点,红色表示当前页面)

 private class VIEwPagechangelistener implements OnPagechangelistener {    @OverrIDe    public voID onPageScrollStateChanged(int arg0) {    }    @OverrIDe    public voID onPageScrolled(int arg0,float arg1,int arg2) {    }    //监听页面改变事件来改变vIEwIndicator中的指示图片    @OverrIDe    public voID onPageSelected(int arg0) {      int len = vIEwIndicator.getChildCount();      for(int i = 0; i < len; ++i)        vIEwIndicator.getChildAt(i).setBackgroundResource(R.drawable.tip_normal);      vIEwIndicator.getChildAt(arg0).setBackgroundResource(R.drawable.tip_select);    }      }

实现一个Handler,用于在一定的时间间隔后修改UI(将当前显示的图片切换到下一个)

private Handler mHandler = new Handler() {    public voID handleMessage(androID.os.Message msg) {      switch(msg.what) {      case 1:        int totalcount = pagers.size();//autochangeVIEwPager.getChildCount();        int currentItem = autochangeVIEwPager.getCurrentItem();                int toItem = currentItem + 1 == totalcount ? 0 : currentItem + 1;                Log.i(TAG,"totalcount: " + totalcount + "  currentItem: " + currentItem + "  toItem: " + toItem);                autochangeVIEwPager.setCurrentItem(toItem,true);                //每两秒钟发送一个message,用于切换vIEwPager中的图片        this.sendEmptyMessageDelayed(1,2000);      }    }  };


上面这3段就是主要的代码,除此之外,还需要在onResume()中发送一个起始message以及在onStop()中停止VIEwPager页面的自动切换等内容。
完整的代码如下:

public class MainActivity extends Activity {  private static final String TAG = MainActivity.class.getSimplename();  private VIEwPager autochangeVIEwPager;    //用来指示当前显示图片所在位置  private linearLayout vIEwIndicator;    //包含要在VIEwPager中显示的图片  private List<VIEw> pagers;  @OverrIDe  protected voID onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentVIEw(R.layout.activity_main);        autochangeVIEwPager = (VIEwPager) findVIEwByID(R.ID.autoVP);    vIEwIndicator = (linearLayout) findVIEwByID(R.ID.vpindicator);        initAdapter();        //监听页面改变事件来改变vIEwIndicator中的指示图片    autochangeVIEwPager.setonPagechangelistener(new VIEwPagechangelistener());      }    private voID initAdapter() {    //即将在vIEwPager中展示的图片资源    int[] imgs = {R.drawable.i1,R.drawable.i2,R.drawable.i3};        //init pagers;    pagers = new ArrayList<VIEw>();    linearLayout.LayoutParams img_params = new LayoutParams(        LayoutParams.MATCH_PARENT,LayoutParams.MATCH_PARENT        );    for(int i = 0; i < imgs.length; ++i) {      ImageVIEw iv = new ImageVIEw(this);      iv.setBackgroundResource(imgs[i]);      iv.setLayoutParams(img_params);      final int index = i;      iv.setonClickListener(new OnClickListener() {        //当vIEwPager中的图片被点击后,跳转到新的activity        @OverrIDe        public voID onClick(VIEw v) {          Intent i = new Intent(MainActivity.this,InvokedActivity.class);          i.putExtra("name","cat " + index);          MainActivity.this.startActivity(i);        }      });      pagers.add(iv);    }    autochangeVIEwPager.setAdapter(new VIEwPagerAdapter(pagers));        //init indicator    linearLayout.LayoutParams ind_params = new LayoutParams(        LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT        );    for(int i = 0; i < imgs.length; ++i) {      ImageVIEw iv = new ImageVIEw(this);      if(i == 0)        iv.setBackgroundResource(R.drawable.tip_select);      else        iv.setBackgroundResource(R.drawable.tip_normal);      iv.setLayoutParams(ind_params);      vIEwIndicator.addVIEw(iv);    }  }    @OverrIDe  protected voID onResume() {    super.onResume();    //activity启动两秒钟后,发送一个message,用来将vIEwPager中的图片切换到下一个    mHandler.sendEmptyMessageDelayed(1,2000);  }    @OverrIDe  protected voID onStop() {    super.onStop();    //停止vIEwPager中图片的自动切换    mHandler.removeMessages(1);  }  public class VIEwPagerAdapter extends PagerAdapter {    private List<VIEw> mData;    public VIEwPagerAdapter(List<VIEw> mData) {      this.mData = mData;    }    @OverrIDe    public int getCount() {      return mData.size();    }    @OverrIDe    public boolean isVIEwFromObject(VIEw arg0,object);      container.removeVIEw(mData.get(position));    }      }    private class VIEwPagechangelistener implements OnPagechangelistener {    @OverrIDe    public voID onPageScrollStateChanged(int arg0) {    }    @OverrIDe    public voID onPageScrolled(int arg0,int arg2) {    }    //监听页面改变事件来改变vIEwIndicator中的指示图片    @OverrIDe    public voID onPageSelected(int arg0) {      int len = vIEwIndicator.getChildCount();      for(int i = 0; i < len; ++i)        vIEwIndicator.getChildAt(i).setBackgroundResource(R.drawable.tip_normal);      vIEwIndicator.getChildAt(arg0).setBackgroundResource(R.drawable.tip_select);    }      }    private Handler mHandler = new Handler() {    public voID handleMessage(androID.os.Message msg) {      switch(msg.what) {      case 1:        int totalcount = pagers.size();//autochangeVIEwPager.getChildCount();        int currentItem = autochangeVIEwPager.getCurrentItem();                int toItem = currentItem + 1 == totalcount ? 0 : currentItem + 1;                Log.i(TAG,2000);      }    }  };}

布局文件如下:(上面代码中的InvokedActivity非常简单,此处就省略了)

<FrameLayout xmlns:androID="http://schemas.androID.com/apk/res/androID"  androID:layout_wIDth="match_parent"  androID:layout_height="match_parent" >  <androID.support.v4.vIEw.VIEwPager    androID:ID="@+ID/autoVP"    androID:layout_wIDth="match_parent"    androID:layout_height="match_parent" />  <linearLayout    androID:ID="@+ID/vpindicator"    androID:layout_wIDth="match_parent"    androID:layout_height="wrap_content"    androID:layout_gravity="bottom"    androID:orIEntation="horizontal" /></FrameLayout>

总结

以上是内存溢出为你收集整理的Android App中用Handler实现ViewPager页面的自动切换全部内容,希望文章能够帮你解决Android App中用Handler实现ViewPager页面的自动切换所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1142069.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存