如果不想依赖,可以参考第二种方式。 用到的方法:Observable的throttleFirst方法实现短时间内的事件过滤。 复制代码
import android.view.View import io.reactivex.Observable import io.reactivex.android.schedulers.AndroidSchedulers import java.util.concurrent.TimeUnit /** * View控件短时间内二次点击的帮助类 */ class DebounceHelper { companion object{ /** * 对View的点击事件在设定的时间内进行防止二次点击,不带View参数的回调 * @param view * @param debounceTime 设定的这个时间内,View点击只有一次起效,时间单位是秒 * @param runnable View的点击后的执行方法的回调 */ fun click(view: View,debounceTime:Long,runnable: Runnable){ Observable.create<View> { var emitter = it view?.setOnClickListener { Log.e("DebounceHelper","点击...") emitter.onNext(it) } }.throttleFirst(debounceTime,TimeUnit.SECONDS) .observeOn(AndroidSchedulers.mainThread()) .subscribe { runnable.run() } } /** * 对View的点击事件在设定的时间内进行防止二次点击,带View参数的回调 * @param view * @param debounceTime 设定的这个时间内,View点击只有一次起效,时间单位是秒 * @param listener View的点击事件回调,带有本身View的参数 */ fun click(view: View,debounceTime:Long,listener:View.OnClickListener){ Observable.create<View> { var emitter = it view?.setOnClickListener { emitter.onNext(it) } }.throttleFirst(debounceTime,TimeUnit.SECONDS) .observeOn(AndroidSchedulers.mainThread()) .subscribe { listener.onClick(it) } } } } 复制代码
DebounceHelper.click(mView,1, Runnable { //执行方法 timeCount++ LoggerUtil.e("clickTextView:$timeCount") Toast.makeText(this.context,"clickTextView:$timeCount",Toast.LENGTH_SHORT).show() }) 复制代码
当logcat显示:点击... ,表示点击了按钮,
显示:clickTextView的时候,表示执行了点击事件。
可以根据logcat显示情况,当View重复点击的时候,在1秒内都是不会去执行点击事件的,虽然已经发生了点击。
下面的第二种方式也是相同的操作。
import android.view.View /** * View点击事件短时间内连续点击的过滤类,避免在重复操作 * @param debounceTime 两次点击的最短间隔时间,在此时间内的点击只执行一次,单位是毫秒,如限制1秒,传入:1000 * @param runnable 点击事件的方法都在该Runnable类中执行。如需返回view作为参数,可将该类替换成 View.OnClickListener */ class DebounceClickListener(var debounceTime: Long, var runnable: Runnable) : View.OnClickListener { var mLastClickTime: Long = System.currentTimeMillis() override fun onClick(view: View?) { if (view == null) return if (mLastClickTime > 0) { val currentTimeMillis = System.currentTimeMillis() val debounceBetweenTime = currentTimeMillis - mLastClickTime //时间大于指定的时间,执行runnable的回调 if (debounceBetweenTime > debounceTime) { mLastClickTime = System.currentTimeMillis() runnable.run() } else { LoggerUtil.e("时间间隔:$debounceBetweenTime") return } } else { mLastClickTime = System.currentTimeMillis() runnable.run() } } } 复制代码
mView.apply { setOnClickListener(DebounceClickListener(1000, Runnable { //执行方法 timeCount++ LoggerUtil.e("clickTextView:$timeCount") Toast.makeText(this.context,"clickTextView:$timeCount",Toast.LENGTH_SHORT).show() })) } 复制代码