android防止左向右滑出程序,Android 动态禁止/允许Viewpager左(右)滑动

释放双眼,带上耳机,听听看~!

最近在做一个仿抖音首页效果。大致结构为, MainActivity里Viewpager带3个fragment,中间的fragment又add了4个Tab(首页,关注,消息,我)

1 玩过抖音的孩子应该有点印象。在首页tab的时候,viewpager左右两个fragment还能滑出来,在关注tab,消息tab,我tab中,viewpager左右就滑不出来了——禁止了Viewpager左右滑动。

2 在首页tab中,还有推荐tab和城市tab,推荐tab正常左右滑动viewpager,而城市tab无法滑出右侧tab——禁止Viewpager右滑

说到底就是需要一个可以动态设置当前是否可以左(右)滑的Viewpager,网上看了下,emm…几乎是写viewpager禁止滑动的,好吧…过人还得自己写。

处理手势

禁止和允许,无非就是要不要处理这个touch事件。

允许——正常情况下,onTouchEvent返回的super.onTouchEvent(event);

禁止——return true

private float lastX;

private static final int LEFT_TO_RIGHT=1;//方向=从左到右

private static final int RIGHT_TO_LEFT=2;//方向=从右到左

//手指是否已经抬起 (如果不加入这个参数判断,在手指抬起的那一刻touch事件return了true,页面会卡在手指离开那时候的偏移位置)

private boolean isUp=true;

@Override

public boolean onTouchEvent(MotionEvent event) {

int direction=0;

switch (event.getAction()){

case MotionEvent.ACTION_DOWN:

isUp=false;

//获取起始坐标值

lastX = event.getX();

break;

case MotionEvent.ACTION_MOVE:

if(event.getX()-lastX<0){//从右到左滑(左滑)

direction=RIGHT_TO_LEFT;

}else {//从左到右滑(右滑)

direction=LEFT_TO_RIGHT;

}

break;

case MotionEvent.ACTION_UP:

isUp=true;

break;

}

if(isUp){

//手指抬起后,不再接管viewpager的事件,让它自由地滑动

return super.onTouchEvent(event);

}else

if(direction==RIGHT_TO_LEFT&&isCanGoRight){

//允许滑动则应该调用父类的方法

return super.onTouchEvent(event);

}else if(direction==LEFT_TO_RIGHT&&isCanGoLeft){

return super.onTouchEvent(event);

}else {

//禁止滑动则不做任何操作,直接返回true即可

return true;

}

}

需要注意的地方是,在ACTION_UP的时候,不管是否某个方向禁止滑动,我们都要把touch事件还给viewpager做他本来想做的事情。不然页面在那一刻会卡住。

Viewpager在滑动的时候,有时候也会崩溃,报native。处理方法就是return super.方法的时候要catch一下。

完整的Viewpager代码

import android.content.Context;

import android.support.v4.view.ViewPager;

import android.util.AttributeSet;

import android.util.Log;

import android.view.MotionEvent;

/**

* Created by KID on 2018/11/14.

* 可动态禁止(允许)左滑/右滑的viewpager

*/

public class ControlViewpger extends ViewPager {

//是否可以滑出左侧页面

private boolean isCanGoLeft = true;

//是否可以画出右侧页面

private boolean isCanGoRight= true;

public ControlViewpger(Context context) {

super(context);

}

public ControlViewpger(Context context, AttributeSet attrs) {

super(context, attrs);

}

public void setCanGoLeft(boolean canGoLeft) {

isCanGoLeft = canGoLeft;

}

public void setCanGoRight(boolean canGoRight) {

isCanGoRight = canGoRight;

}

@Override

public boolean onInterceptTouchEvent(MotionEvent ev) {

try {

return super.onInterceptTouchEvent(ev);

} catch (IllegalArgumentException ex) {

ex.printStackTrace();

Log.d("kid","IllegalArgumentException发生了");

}

return false;

}

private float lastX;

private static final int LEFT_TO_RIGHT=1;//方向=从左到右

private static final int RIGHT_TO_LEFT=2;//方向=从右到左

//手指是否已经抬起 (如果不加入这个参数判断,在手指抬起的那一刻touch事件return了true,页面会卡在手指离开那时候的偏移位置)

private boolean isUp=true;

@Override

public boolean onTouchEvent(MotionEvent event) {

int direction=0;

switch (event.getAction()){

case MotionEvent.ACTION_DOWN:

isUp=false;

//获取起始坐标值

lastX = event.getX();

break;

case MotionEvent.ACTION_MOVE:

if(event.getX()-lastX<0){//从右到左滑(左滑)

direction=RIGHT_TO_LEFT;

}else {//从左到右滑(右滑)

direction=LEFT_TO_RIGHT;

}

break;

case MotionEvent.ACTION_UP:

isUp=true;

break;

}

if(isUp){

//手指抬起后,不再接管viewpager的事件,让它自由地滑动

return tryCatchError(event);

}else

if(direction==RIGHT_TO_LEFT&&isCanGoRight){

//允许滑动则应该调用父类的方法

return tryCatchError(event);

}else if(direction==LEFT_TO_RIGHT&&isCanGoLeft){

//允许滑动则应该调用父类的方法

return tryCatchError(event);

}else {

//禁止滑动则不做任何操作,直接返回true即可

return true;

}

}

/**

* viewpager滑动偶尔莫名其妙崩溃报native,捕获异常以后,出现这种情况的时候App不会崩溃,只是卡顿那一短暂时间后继续正常操作

* @param event

* @return

*/

private boolean tryCatchError(MotionEvent event){

try {

return super.onTouchEvent(event);

} catch (IllegalArgumentException ex) {

ex.printStackTrace();

Log.d("kid","捕获浏览报错4");

}

return false;

}

}

根据自己业务需求,在某个时刻调用 mViewpger.setCanGoLeft 和 mViewpger.setCanGoRight, 控制viewpager当前是否可滑出左侧或右侧页面。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值