当前位置: 移动技术网 > 移动技术>移动开发>Android > Android开发教程之如何屏蔽View的重复点击

Android开发教程之如何屏蔽View的重复点击

2019年08月02日  | 移动技术网移动技术  | 我要评论

前言

android 防止重复点击是一个非常常见的需求,每个人都有各自的点击事件的处理习惯,有的喜欢使用匿名内部类,有的activity、fragment、自定义view等继承点击事件然后在onclick()方法中根据id用switch实现各自view的点击事件。

在开发中我们经常需要这样的需求,比如一个验证码发送按钮,我们只想让它响应500毫秒中的第一次点击事件,该如何处理呢?你可能会说这个简单,在点击事件中获取当前时间与上次的比较下,如果小于500毫秒就return掉。是的,这样可以解决,但是如果现在整个项目的所有按钮点击事件都需要这样的需求,该如何处理?不可能内个点击事件中都加入这几行代码吧。

这里先放上我写的一个响应第一次点击的工具类,可实现2种模式:

  • 第一种:无论点击的哪个view,仅响应第一次点击
  • 第二章:同一个view上仅响应第一次点击,不同view间无影响
public class clickhelper {

 private static long delay = 500l;
 private static long lasttime = 0l;
 private static list<integer> viewids = null;
 private static final int same_view_size = 10;

 private clickhelper() {
 }

 public static void setdelay(long delay) {
  clickhelper.delay = delay;
 }

 public static long getdelay() {
  return delay;
 }

 public static void onlyfirstignoreview(final view target, @nonnull final callback callback) {
  long nowtime = system.currenttimemillis();
  if (nowtime - lasttime > delay) {
   callback.onclick(target);
   lasttime = nowtime;
  }
 }

 public static void onlyfirstsameview(final view target, @nonnull final callback callback) {
  long nowtime = system.currenttimemillis();
  int id = target.getid();
  if (viewids == null) {
   viewids = new arraylist<>(same_view_size);
  }
  if (viewids.contains(id)) {
   if (nowtime - lasttime > delay) {
    callback.onclick(target);
    lasttime = nowtime;
   }
  } else {
   if (viewids.size() >= same_view_size) {
    viewids.remove(0);
   }
   viewids.add(id);
   callback.onclick(target);
   lasttime = nowtime;
  }
 }

 public interface callback {
  void onclick(view view);
 }
}

那如何才能让它对整个项目的所有点击事件生效呢?我的解决办法是这样的。

第一步,继承view.onclicklistener在onclick方法中调用工具类回调到抽象方法,项目中所有的点击事件都去继承这个抽象类

public abstract class onfirstclicklistener implements view.onclicklistener {

 @override
 public final void onclick(final view v) {
  clickhelper.onlyfirstsameview(v, new clickhelper.callback() {
   @override
   public void onclick(view view) {
    onfirstclick(view);
   }
  });
 }

 public abstract void onfirstclick(view v);
}

第二步,在项目的baseactivity中实现view.onclicklistener接口,在onclick方法中调用工具类,回调出屏蔽后的点击事件,子类复写onclickwithoutlogin或者onclickchecklogin方法就可以了。至于为什么会有2个,看名字就知道了,一个验证了用户登录状态,仅在登录状态响应事件,未登录则跳转登录界面,多封装了一层罢了。

/**
 * 用注解绑定点击事件时,在该方法绑定
 */
@override
public void onclick(final view v) {
  clickhelper.onlyfirstsameview(v, new clickhelper.callback() {
    @override
    public void onclick(view view) {
      if (!onclickwithoutlogin(view)) {
        if (userutils.doiflogin(getcontext())) {
          onclickchecklogin(view);
        }
      }
    }
  });
}

/**
 * 不需要登录的点击事件
 */
public boolean onclickwithoutlogin(view v) {
  return false;
}

/**
 * 必须登录的点击事件
 * 如果已经登录直接执行,没有登录时跳转登录界面
 */
public void onclickchecklogin(view v) {
}

以上只是个人开发中用到的,如果大家有更好的方法,欢迎留言讨论。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网