ViewPager 取消滑动效果,禁止手指滑动

本文介绍了一种自定义ViewPager的方法,通过重写ViewPager类实现禁止手势滑动的功能,并结合RadioGroup实现页面间的联动效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

重写viewPager
/**
 * Created by Bellion on 2016/3/30.
 */
public class CustomViewPager extends ViewPager {
    private boolean noScroll = false;

    public CustomViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
        // TODO Auto-generated constructor stub
    }

    public CustomViewPager(Context context) {
        super(context);
    }

    public void setNoScroll(boolean noScroll) {
        this.noScroll = noScroll;//灵活的设置是否需要手指滑动</span>
    }

    @Override
    public void scrollTo(int x, int y) {
        super.scrollTo(x, y);
    }

    @Override
    public boolean onTouchEvent(MotionEvent arg0) {
        /* return false;//super.onTouchEvent(arg0); */
        if (noScroll)
            return false;//设置手指不能滑动条件一</span>
        else
            return super.onTouchEvent(arg0);
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent arg0) {
        if (noScroll)
            return false;//设置手指不能滑动条件二,也是最后的条件</span>
        else
            return super.onInterceptTouchEvent(arg0);
    }

    @Override
    public void setCurrentItem(int item, boolean smoothScroll) {
        super.setCurrentItem(item, smoothScroll);
    }

    @Override
    public void setCurrentItem(int item) {
        super.setCurrentItem(item,false);//设置viewpager没有切换动画,直接显现</span>
    }
}


用来和RadioGroup做联动时,防止viewpager自己变化,只通过点击radioButton来切换。


在activity中这样写

 customViewPagerAdapter = new CustomViewPagerAdapter(this);
        viewPager.setAdapter(customViewPagerAdapter);
        viewPager.setNoScroll(true);//设置为不对滑动做出反应</span>
        radioGroup.setOnCheckedChangeListener(
                new RadioGroup.OnCheckedChangeListener() {
                    @Override
                    public void onCheckedChanged(RadioGroup group, int checkedId) {
                        RadioButton radioButton;
                        for (int index = 0; index < group.getChildCount(); index++) {
                            radioButton = (RadioButton) group.getChildAt(index);
                            if (radioButton.isChecked()) {
                                viewPager.setCurrentItem(index);
                            }
                        }
                    }
                }
        );



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值