时间:2021-05-21
1. 既适用于单个View事件防抖, 也适用于Adapter中ItemView事件防抖
2. 如果事件为跳转到新的Activity, 该Activity启动模型应为android:launchMode="singleTop"
可简写为
public abstract class NoShakeListener implements OnClickListener { private long mLastClickTime = 0; private boolean isFastDoubleClick() { long nowTime = System.currentTimeMillis(); if (Math.abs(nowTime - mLastClickTime) < 500) { return true; // 快速点击事件 } else { mLastClickTime = nowTime; return false; // 单次点击事件 } } @Override public void onClick(View v) { if (isFastDoubleClick()) { onFastClick(v); } else { onSingleClick(v); } } protected void onFastClick(View v) { } protected abstract void onSingleClick(View v);}差点忘了... 相应的扩展函数:
fun View?.noShake(block: (v: View?) -> Unit) { this?.apply { setOnClickListener(object : NoShakeClickListener() { override fun onSingleClick(v: View?) { block.invoke(v) } }) }}1 移除了对View.OnClickListener的依赖, 在不破坏原有代码已设置好的OnClickListener基础上继续处理事件防抖;
2 支持简单处理事件和泛型回调
/** * 事件防抖 * 注: 不仅适用于 View , 其他控件如: MenuItem 同样适用 * * 1.既适用于单个`View`事件防抖, 也适用于`Adapter`中`ItemView`事件防抖 * 2.如果事件为跳转到新的`Activity`, 该`Activity`启动模型应为`android:launchMode="singleTop"` */open class NoShakeClickListener2 @JvmOverloads constructor(interval: Long = 500L) { private var mTimeInterval = 500L private var mLastClickTime: Long = 0 //最近一次点击的时间 private var mLastClick: Any? = null //最近一次点击的控件 View or MenuItem ... init { mTimeInterval = interval } fun proceedClick() { if (isFastClick(null, mTimeInterval)) onFastClick(null) else onSingleClick(null) } fun <T> proceedClick(item: T?) { if (isFastClick(item, mTimeInterval)) onFastClick(item) else onSingleClick(item) } /** * 是否是快速点击 * * @param item 点击的控件 View or MenuItem ... * @param interval 时间间期(毫秒) * @return true:是,false:不是 */ private fun <T> isFastClick(item: T?, interval: Long): Boolean { val nowTime = System.currentTimeMillis() val timeInterval = abs(nowTime - mLastClickTime) return if (timeInterval < interval && item == mLastClick) { // 快速点击事件 true } else { // 单次点击事件 mLastClickTime = nowTime mLastClick = item false } } protected open fun onFastClick(item: Any?) {} protected open fun onSingleClick(item: Any?) {}}1 简单使用
//快速点击事件val fastClick=object :NoShakeClickListener2(){ override fun onFastClick(item: Any?) { super.onFastClick(item) //此时 item == null Log.e("123", "onFastClick Click") }}BottomNavigationView.setOnNavigationItemSelectedListener { switchPage(it.itemId) fastClick.proceedClick() true}2 回传参数
//快速点击事件val fastClick=object :NoShakeClickListener2(){ override fun onFastClick(item: Any?) { super.onFastClick(item) //此时 item == null 为 proceedClick(it) 中的 it Log.e("123", "onFastClick Click") }}BottomNavigationView.setOnNavigationItemSelectedListener { switchPage(it.itemId) fastClick.proceedClick(it) true}以上就是Android View 事件防抖的两种方案的详细内容,更多关于Android View 事件防抖的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Android自定义View的构造函数自定义View是Android中一个常见的需求,每个自定义的View都需要实现三个基本的构造函数,而这三个构造函数又有两种
本节引言前两节中我们对Android中的两种事件处理机制进行了学习,关于响应的事件响应就这两种;本节给大家讲解的是Activity中UI组件中的信息传递Hand
javascript,jquery的事件中都存在事件冒泡和事件捕获的问题,下面将两种问题及其解决方案做详细总结。事件冒泡是一个从子节点向祖先节点冒泡的过程;事件
下文我们介绍两种双击事件拦截的方式1.通过Android的事件分发机制进行拦截(dispatchTouchEvent)话不多说,直接上代码:/**判断是否是快速
Android中播放视频主要有两种方式:使用其自带的播放器。指定Action为ACTION_VIEW,Data为Uri,Type为其MIME类型使用androi