ViewPager2左右滑动判断

    // viewpager滑动状态判断,true滑动了,false没有滑动
    private boolean isScrolling = false;

    viewPager2.registerOnPageChangeCallback(new ViewPager2.OnPageChangeCallback() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
                super.onPageScrolled(position, positionOffset, positionOffsetPixels);
            }

            @Override
            public void onPageSelected(int position) {
                super.onPageSelected(position);
            }

            @Override
            public void onPageScrollStateChanged(int state) {
                super.onPageScrollStateChanged(state);
                //state 1开始滑动 2滑动结束 0什么都没做 滑动过程1-2-0
                if (state == 1) {
                    isScrolling = false;
                }
                if (state == 2) {
                    isScrolling = true;
                }
                if (state == 0) {
                    if (!isScrolling) {  // 没有滑动,说明滑到底了
                        if (currentPosition == detailsData.size() - 1) {
                            // 最后一页,加载下一项数据
                            loadNextItemData();
                        } else if (currentPosition == 0) {  
                            // 第一页
                            loadLastItemData();
                        }
                    }
                }
            }
        });

 这是我第一次的写法,其实如果数据大于一条时(detailsData.size()>1),这样是没问题的,但是当数据只有一条时,这样就不行,就要判断滑动方向了。

    // viewpager滑动状态判断,true滑动了,false没有滑动
    private boolean isScrolling = false;
    private float downX;  // 按下时x坐标
    private boolean isLeft = false;  // 是否往左滑

    @Override
    public boolean dispatchTouchEvent(MotionEvent ev) {
        switch (ev.getAction()) {
            case MotionEvent.ACTION_DOWN:
                downX = ev.getX();
                break;
            case MotionEvent.ACTION_UP:
                if (ev.getX() - downX > 0) {
                    // 往右滑动,查看上一页
                    isLeft = false;
                } else {
                    // 往左滑动,查看下一页
                    isLeft = true;
                }
                break;
        }
        return super.dispatchTouchEvent(ev);
    }

    viewPager2.registerOnPageChangeCallback(new ViewPager2.OnPageChangeCallback() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
                super.onPageScrolled(position, positionOffset, positionOffsetPixels);
            }

            @Override
            public void onPageSelected(int position) {
                super.onPageSelected(position);
            }

            @Override
            public void onPageScrollStateChanged(int state) {
                super.onPageScrollStateChanged(state);
                //state 1开始滑动 2滑动结束 0什么都没做 滑动过程1-2-0
                if (state == 1) {
                    isScrolling = false;
                }
                if (state == 2) {
                    isScrolling = true;
                }
                if (state == 0) {
                    if (!isScrolling) {  // 没有滑动,说明滑到底了
                        if (isLeft) {
                            // 左滑,查看下一页

                        } else {
                            // 右滑,查看上一页

                        }
                    }
                }
            }
        });

这是现在的写法,加了左右滑动的判断

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值