ViewPager和View的事件响应规则

案例背景:
  当我们实现viewpager的自动切换界面操作的时候,如果需要增加点击图片viewpager停止自动切换,松开手指viewpager自动切换又继续执行的逻辑,正常思维下实现代码如下所示:

利用handler发送消息实现viewpager 自动滑动
        if (handler == null) {
            handler = new Handler(){
                @Override
                public void handleMessage(Message msg) {
                    super.handleMessage(msg);
                    // 实现切换 viewpager 界面
                    // 获取当前显示界面的索引
                    int currentItem = mViewPager.getCurrentItem();
                    // 计算下一个界面的索引
                    // 判断如果切换到最后一个界面,需要重新切换回第一个界面进行操作
                    if (currentItem == imageurls.size()-1) {
                        currentItem=0;
                    }else{
                        currentItem++;
                    }
                    // 设置 viewpager 显示下一个界面
                    mViewPager.setCurrentItem(currentItem);
                    // 一次切换完成,还需要接着执行第二次
                    handler.sendEmptyMessageDelayed(0, 3000);
                }
            };
            handler.sendEmptyMessageDelayed(0, 3000);// 延迟 3 秒个 handler 发送消息
        }        


        // 设置 viewpager 条目界面的触摸事件,实现按下 viewpager 停止滑动,抬起 viewpager 重新滑动
        rootview.setOnTouchListener(new OnTouchListener() {
            @Override
            public boolean onTouch(View v, MotionEvent event) {
            switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                // 停止发送 handler 延迟消息
                handler.removeCallbacksAndMessages(null);// 参数如果是 null ,表示删除所有的延迟消息
                break;
            case MotionEvent.ACTION_UP:
                // 重新发送 handler 延迟消息,实现 viewpager 自动滑动
                handler.sendEmptyMessageDelayed(0, 3000);
                break;
            }
            // 返回 true: 执行触摸监听操作, false :不执行
            return true;
            }
        });

  即:在手指按下的时候利用handler发送停止消息而到当手指抬起的时候发送继续切换的消息 然而在实际的操作中我们发现当手指抬起的时候viewpager不能继续实现自动切换,通过对代码进行log操作发现手指抬起的时候view并没有执行up方法而是执行了cancel方法,故代码修改如下:

// 设置 viewpager 条目界面的触摸事件,实现按下 viewpager 停止滑动,抬起 viewpager 重新滑动
    rootview.setOnTouchListener(new OnTouchListener() {
        @Override
        public boolean onTouch(View v, MotionEvent event) {
            switch (event.getAction()) {
                case MotionEvent.ACTION_DOWN:
                // 停止发送 handler 延迟消息
                handler.removeCallbacksAndMessages(null);// 参数如果是 null ,表示删除所有的延迟消息
                break;
            case MotionEvent.ACTION_UP:
                // 重新发送 handler 延迟消息,实现 viewpager 自动滑动
                handler.sendEmptyMessageDelayed(0, 3000);
                break;
            case MotionEvent.ACTION_CANCEL:
                // 当取消 view 的事件的时候,重新让 viewpager 自动滑动
                handler.sendEmptyMessageDelayed(0, 3000);
                break;
            }
            // 返回 true: 执行触摸监听操作, false :不执行
            return true;
        }
    });

即:增加cancel方法的条目在方法内实现继续发送切换消息的逻辑。

规则总结:
    1、如果手指缓慢滑动很短的距离,viewpager没有切换界面,所以认为viewPager和view都可以执行事件,系统不会取消任何控件的触摸事件,由我们自己决定处理哪个事件。
    2、如果手指快速滑动很长的距离,viewpager就会执行界面切换,此时view就会执行cancel方法,取消view的触摸事件,只执行viewPager的触摸事件。

 

转载于:https://www.cnblogs.com/yegong0214/p/6274736.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在ViewPager中设置点击事件,需要使用ViewPager.OnPageChangeListener和ViewPager.OnTouchListener两个接口。这些接口可以让您监听ViewPager的滑动和触摸事件。 以下是一个简单的例子,演示如何使用这两个接口来设置ViewPager的点击事件: ```java // 获取ViewPager实例 ViewPager viewPager = findViewById(R.id.viewPager); // 设置页面改变监听器 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) {} }); // 设置触摸监听器 viewPager.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View view, MotionEvent motionEvent) { // 检测到点击事件 if (motionEvent.getAction() == MotionEvent.ACTION_UP) { // 处理点击事件 int position = viewPager.getCurrentItem(); // TODO: 处理点击事件 return true; } return false; } }); ``` 在上面的例子中,我们首先获取了ViewPager实例,然后使用addOnPageChangeListener()方法设置了一个空的页面改变监听器。接下来,我们使用setOnTouchListener()方法设置了一个触摸监听器,用于监听用户点击事件。在这个监听器中,我们检测到了MotionEvent.ACTION_UP事件,即用户松开了手指,这时就可以处理点击事件了。我们可以使用getCurrentItem()方法获取当前页面的位置,然后在处理点击事件时使用该位置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值