关于自动滚动无限循环viewpager的问题

问题:一个项目通常都要用到viewpager,往往伴随的功能有自动滚动,循环滚动的功能,在网上找了半天,发现人家都用开源的,或者自己封装方法,很难理解,自己写的代码有时候还不一定符合他封装工具的需求。

解决:利用系统自带的最原始的viewpager即可实现循环自动滚动的功能。

    if (position == 0) {
                convertView = LayoutInflater.from(context).inflate(
                        R.layout.xinwenfrag_viewpager, null);
                Log.e("yan", "执行条目一" + users.size());
                vp = (ViewPager) convertView
                        .findViewById(R.id.xinwen_viewpager_two);
                xinwenpageradapter = new XinwenPagerAdapter(context, users);
                vp.setAdapter(xinwenpageradapter);
                //为ViewPager设置一个当前页(为了实现ViewPager的反向滑动),正常情况下ViewPager刚开始不能反向滑(viewpager的数目已经设置为无限大)
                vp.setCurrentItem(users.size()*100);
                //定时跳到下一个
                handler = new Handler(){
                    public void handleMessage(android.os.Message msg) {
                        vp.setCurrentItem(vp.getCurrentItem()+1, true);
                    };
                };
                startSlide();
                // 解决新闻头部循环问题
                vp.setOnPageChangeListener(new OnPageChangeListener() {
                    Boolean isScrolled = true;
                    @Override
                    public void onPageSelected(int arg0) {
                        Log.e("yan", "onPageSelected");
                    }
                    @Override
                    public void onPageScrolled(int arg0, float arg1, int arg2) {
                        Log.e("yan", "onPageScrolled");
                    }

                    @Override
                    public void onPageScrollStateChanged(int status) {

                        switch (status) {
                        case 1:// 手势滑动
                            isScrolled = false;
                            stopSlide();
                            break;
                        case 2:// 界面切换
                            isScrolled = true;
                            break;
                        case 0:// 滑动结束
                            startSlide();
                            // 当前为最后一张,此时从右向左滑,则切换到第一张
                            if (vp.getCurrentItem() == vp.getAdapter()
                                    .getCount() - 1 && !isScrolled) {
                                vp.setCurrentItem(0);
                            }
                            // 当前为第一张,此时从左向右滑,则切换到最后一张
                            else if (vp.getCurrentItem() == 0 && !isScrolled) {
                                vp.setCurrentItem(vp.getAdapter().getCount() - 1);
                            }
                            break;
                        }

                    }
                });
               
这段代码是写在listview适配器中的代码,也就是适配器中又有了新的适配器,所以跟网上提供的代码有的时候不能吻合,必须得自己解决。

实现思想就是在XinwenPagerAdapter中数目返回最大

@Override
    public int getCount() {
        if (users.size() > 0) {
            Log.e("yan", users.size()+"$$$$$$");
            return Integer.MAX_VALUE;
        
        }
        return 0;
        
    }

但是问题又有了,viewpager刚开始不能向左滑动,所以此刻应该设个vp.setCurrentItem(users.size()*100)  应该不会有人真的去向左滑动users.size()*100次吧,要是不放心,可以把100设为1000

这样就实现了循环的功能。


定时播放就更简单了,只要封装两个方法即可

/**
     * 启动定时滑动线程
     */
    public void startSlide(){
        if(task == null){

            task = new TimerTask() {

                @Override
                public void run() {
                    handler.sendEmptyMessage(0);
                }
            };
            timer.schedule(task, 5*1000, 5*1000);
        }
    }
    
    /**
     * 退出定时滑动线程
     */
    public void stopSlide(){
        if(task != null){
            task.cancel();
            task = null;
        }
    }

在vp的监听事件中当手指触摸了就stopslide(),触摸结束就startslide()


以上就是解决方法。


转载请注明出处!


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值