JavaFx 实现按钮防抖
2022-01-22 16:23
1196 查看
原文地址:JavaFx 实现按钮防抖 | Stars-One的杂货小窝
Android平台的APP,一般是有需要进行设置按钮的防抖(即在短时间内无法多次点击),我想在JavaFx项目中也是实现防抖功能,便是研究了下
实现原理
点击按钮前,需要记录当前点击的时间,在按钮下一次点击的时候,与之前记录的点击时间进行计算,判断两者的间隔时间是否大于设定的条件值
这里思路没有是嘛难度,主要是点击时间的历史记录该如何 ad8 记录?有以下几种方法
- 使用Map存储(按钮过多占用资源较大)
- 使用控件对象提供的某个无用字段进行存储
在Android中,可以使用View中的tag来保存信息
而在JavaFx中,所有的控件都有userData的字段,有了这个,我们即可去存储时间
实现代码
Kotlin版:
kotlin版我是使用了扩展方法,对BUtton类进行了扩展,不太明白扩展方法的可以查下资料,简单来说即是给Button类新增了个方法
//注意Button是javafx包的 fun Button.isFastClick(): Boolean { val lastClickTime = userData as Long? val currentTime = System.currentTimeMillis() userData = currentTime //这里我设置为1s内多次点击无效,可以根据需要调整 if (lastClickTime != null && currentTime - lastClickTime <= 1000) { return true } return false }
使用:
button{ action { //不是快速点击才进入点击逻辑 if (!isFastClick()) { println("hello") } } }
Kotlin优化版
稍微重新封装了下,使用更加优雅
/** * 是否快速点击 */ fun Button.isFastClick(time:Long): Boolean { val lastClickTime = userData as Long? val currentTime = System.currentTimeMillis() userData = currentTime if (lastClickTime != null && currentTime - lastClickTime <= time) { return true } return false } /** * 设置防抖的按钮Action * @param time 单位毫秒,默认1000(1s内防抖) */ fun Button.setActionHank(time:Long = 1000,op: () -> Unit) { action { if (!isFastClick(time)) { op() } } }
使用:
button("测试") { //这里不用action了 setActionHank{ println("111") } }
PS:后续会收录到common-controls的库中
Java版
class ButtonUtils { public static boolean isFastClick(Button button) { Object userData = button.getUserData(); long currentTime = System.currentTimeMillis(); button.setUserData(currentTime); if (userData instanceof Long) { Long lastClickTime = (Long) userData; return currentTime - lastClickTime <= 1000; } return false; } }
测试效果
相关文章推荐
- 利用RxJava和 RxBinding实现倒计时按钮、关键词搜索和按钮防抖效果
- 用JavaFX实现图片(和按钮)随窗口大小变化而变化
- 关于VC6 MFC使用Gdiplus实现自绘按钮的总结
- javascript控制点击一次按钮实现元素的显示隐藏
- Android - ImageButton单击切换按钮图片效果的实现
- 点击按钮弹出文件夹选择框的实现
- 原生js实现表单的正则验证,所有验证都通过后提交按钮才可用
- CSS实现圆角六色渐变自适应按钮详解
- QT实现图片按钮(用qss切割图片,或者放三张图片)
- javafx TableValue 添加按钮列,以及删除列功能
- 开关按钮实现
- 按钮的监听事件在fragment中如何实现
- Button按钮实现返回键功能
- 自绘按钮的实现
- 移动端实现点击按钮复制功能
- iphone开发之UIButton按钮的使用(二)拖线实现 多个按钮用同一个监听方法实现
- 学习笔记之——FragmentTabHost实现中间按钮凸出效果
- 使用表格布局实现界面计算器按钮
- 第二人生的源码分析(九十八)LLIconCtrl实现图标按钮显示
- 实现确认按钮出现遮蔽网页其他内容,捕获传统保存快捷组合键