1.设置activity启动模式为SingleTop
缺点:容易遗漏
2.通过拦截触摸事件的派发
@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
if (ev.getAction() == MotionEvent.ACTION_DOWN) {
if (checkDoubleClick()) {
return true;
}
}
return super.dispatchTouchEvent(ev);
}
/** 判断是否是快速点击 */
private static long lastClickTime;
public static boolean checkDoubleClick() {
//点击时间
long clickTime = SystemClock.uptimeMillis();
//如果当前点击间隔小于500毫秒
if (lastClickTime >= clickTime - 500) {
return true;
}
//记录上次点击时间
lastClickTime = clickTime;
return false;
}
缺点: 会导致页面跳转后的500ms所有的点击都失效
3.拦截startActivity方法,查看源码得知startActivity方法最终走的是startActivityForResult方法,重写startActivityForResult
/**
* 每次启动activity都会调用此方法
*/
@SuppressLint("RestrictedApi")
@Override
public void startActivityForResult(Intent intent, int requestCode, @Nullable Bundle options) {
if (checkDoubleClick(intent)) {
super.startActivityForResult(intent, requestCode, options);
}
}
private String mActivityJumpTag; //activity跳转tag
private long mClickTime; //activity跳转时间
/**
* 检查是否重复跳转,不需要则重写方法并返回true
*/
protected boolean checkDoubleClick(Intent intent) {
// 默认检查通过
boolean result = true;
// 标记对象
String tag;
if (intent.getComponent() != null) { // 显式跳转
tag = intent.getComponent().getClassName();
}else if (intent.getAction() != null) { // 隐式跳转
tag = intent.getAction();
}else {
return true;
}
if (tag.equals(mActivityJumpTag) && mClickTime >= SystemClock.uptimeMillis() - 500) {
// 检查不通过
result = false;
}
// 记录启动标记和时间
mActivityJumpTag = tag;
mClickTime = SystemClock.uptimeMillis();
return result;
}
通过设置tag区分跳转的activity,避免影响到其他页面的跳转事件
我用的是方法2 亲测可用