Android使用ViewPager做无限轮播,人为滑动时停止

简介: Android使用ViewPager做无限轮播,人为滑动时停止

实现无限循环

使用取模,获取到当前图片所在的位置。

    private class MyPagerAdapter extends PagerAdapter {
        private Context context;
        List<ImageView> list;

        public MyPagerAdapter(Context context, List<ImageView> list) {
            this.context = context;
            this.list = list;
        }

        @Override
        public int getCount() {
            //使用Integer的最大值,这样基本上就不需要滑动到最后了
            //除非用户很蛋疼
            return Integer.MAX_VALUE;
        }

        @Override
        public Object instantiateItem(ViewGroup container, int position) {
            //当前位置模上总数等于图片在数组中的位置
            position %= list.size();
            if (position < 0) {
                position = list.size() + position;
            }
            ImageView imageView = list.get(position);
            //设置轮播点击事件
            final int finalPosition = position;
            imageView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    Intent intent = new Intent(getApplicationContext(), BannerActivity.class);
                    intent.putExtra("position", finalPosition);
                    startActivity(intent);
                }
            });
            ViewGroup parent = (ViewGroup) imageView.getParent();
            if (parent != null) {
                parent.removeView(imageView);
            }
            container.addView(imageView);
            return list.get(position);
        }

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

        @Override
        public void destroyItem(ViewGroup container, int position, Object object) {
            //注意这里不要使用
            //container.removeView(list.get(position));
        }
    }

自动循环实现

使用Handler每隔5秒一次消息,接收到轮播的动作就继续发一次消息,实现自动轮播的效果。

    private class MyHandler extends Handler {
        private Context context;
        //使用弱引用,避免handler造成内存泄露
        private WeakReference<MainActivity> weakReference;

        public MyHandler(WeakReference<MainActivity> weakReference) {
            this.weakReference = weakReference;
        }


        @Override
        public void handleMessage(Message msg) {
            MainActivity activity = weakReference.get();
            //Activity不存在了,就不需要再处理了
            if (activity == null) {
                return;
            }
            //如果已经有消息了,先移除消息
            if (activity.handler.hasMessages(BANNER_NEXT)) {
                activity.handler.removeMessages(BANNER_NEXT);
            }
            switch (msg.what) {
                case BANNER_NEXT:
                    //跳到下一页,
                    int currentItem = vpBanner.getCurrentItem();
                    activity.vpBanner.setCurrentItem(++currentItem);
                    //5秒后继续轮播
                    activity.handler.sendEmptyMessageDelayed(BANNER_NEXT, 5000);
                    break;
                case BANNER_PAUSE:
                    //暂停,不需要做任务操作
                    break;
                case BANNER_RESUME:
                    //继续轮播
                    activity.handler.sendEmptyMessageDelayed(BANNER_NEXT, 5000);
                    break;
            }
        }
    }

在Activity中使用

        //这里放了3张图片,使用Gilde加载
        ImageView imageView1 = new ImageView(this);
        ImageView imageView2 = new ImageView(this);
        ImageView imageView3 = new ImageView(this);
        RequestManager requestManager = Glide.with(this);
        requestManager.load("http://img1.imgtn.bdimg.com/it/u=3251910782,1174316217&fm=21&gp=0.jpg").into(imageView1);
        requestManager.load("http://pic2.ooopic.com/10/78/50/34b1OOOPICf0.jpg").into(imageView2);
        requestManager.load("http://www.swkweike.com/data/uploads/2015/08/18/193226787255d2dbd711a33.jpg").into(imageView3);
        List<ImageView> list = new ArrayList<>();
        list.add(imageView1);
        list.add(imageView2);
        list.add(imageView3);
        MyPagerAdapter adapter = new MyPagerAdapter(this, list);
        vpBanner = (ViewPager) findViewById(R.id.vpBanner);
        vpBanner.setAdapter(adapter);
        //将起始位置设置在中间,让用户看不到边界
        vpBanner.setCurrentItem(Integer.MAX_VALUE / 2);
        //开始轮播
        handler.sendEmptyMessageDelayed(BANNER_NEXT, 5000);

用户滑动时停止轮播,松开时继续轮播

使用ViewPager的滑动监听事件,判断用户是否正在滑动

        vpBanner.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) {
                switch (state) {
                    case ViewPager.SCROLL_STATE_DRAGGING:
                        //用户正在滑动,暂停轮播
                        handler.sendEmptyMessage(BANNER_PAUSE);
                        break;
                    case ViewPager.SCROLL_STATE_IDLE:
                        //滑动结束,继续轮播
                        handler.sendEmptyMessageDelayed(BANNER_NEXT, 5000);
                        break;
                }

            }
        });
相关文章
|
5月前
|
JavaScript Android开发
使用贝叶斯曲线滑动安卓屏幕(autojsPro7)
使用贝叶斯曲线滑动安卓屏幕(autojsPro7)
220 0
|
4月前
|
Android开发 容器
35. 【Android教程】视频页面:ViewPager
35. 【Android教程】视频页面:ViewPager
53 3
|
3月前
|
Android开发
Android仿高德首页三段式滑动
Android仿高德首页三段式滑动
107 0
|
4月前
|
编解码 Android开发
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
65 0
|
4月前
|
XML Android开发 UED
|
5月前
|
Android开发
Android使用ViewPager实现图片轮播系列之三:手动滑动 + 左右箭头(1)
Android使用ViewPager实现图片轮播系列之三:手动滑动 + 左右箭头(1)
|
5月前
|
Android开发 Kotlin 索引
Android Compose——ScrollableTabRow和LazyColumn同步滑动
Android Compose——ScrollableTabRow和LazyColumn同步滑动
270 0
|
Android开发
Android功能总结:仿照Launcher的Workspace实现左右滑动切换
      对于Launcher的桌面滑动大家应该都比较熟悉了,最好的体验应该是可以随着手指的滑动而显示不同位置的桌面, 比一般用ViewFlinger+动画所实现的手势切换页面感觉良好多了~~~~ 分析了一下Launcher中的WorkSpace,里面有太多的代码我们用不上了(拖拽,长按,,,),把里面的冗余代码去掉得到实现滑动切换屏幕所必需的。
855 0
|
13天前
|
缓存 搜索推荐 Android开发
安卓开发中的自定义控件实践
【10月更文挑战第4天】在安卓开发的海洋中,自定义控件是那片璀璨的星辰。它不仅让应用界面设计变得丰富多彩,还提升了用户体验。本文将带你探索自定义控件的核心概念、实现过程以及优化技巧,让你的应用在众多竞争者中脱颖而出。
|
13天前
|
Java Android开发 Swift
安卓与iOS开发对比:平台选择对项目成功的影响
【10月更文挑战第4天】在移动应用开发的世界中,选择合适的平台是至关重要的。本文将深入探讨安卓和iOS两大主流平台的开发环境、用户基础、市场份额和开发成本等方面的差异,并分析这些差异如何影响项目的最终成果。通过比较这两个平台的优势与挑战,开发者可以更好地决定哪个平台更适合他们的项目需求。
51 1