javafx 是一个开源的下一代客户端应用平台,适用于基于java构建的桌面、移动端和嵌入式系统。 它是许多个人和公司的共同努力的成果,目的是为开发丰富的客户端应用提供一个现代、高效、功能齐全的工具包。
javafx中文网站
android平台的app,一般是有需要进行设置按钮的防抖(即在短时间内无法多次点击),我想在javafx项目中也是实现防抖功能,便是研究了下
点击按钮前,需要记录当前点击的时间,在按钮下一次点击的时候,与之前记录的点击时间进行计算,判断两者的间隔时间是否大于设定的条件值
这里思路没有是嘛难度,主要是点击时间的历史记录该如何记录?有以下几种方法
使用map存储(按钮过多占用资源较大)使用控件对象提供的某个无用字段进行存储在android中,可以使用view中的tag来保存信息
而在javafx中,所有的控件都有urdata的字段,有了这个,我们即可去存储时间
kotlin版我是使用了扩展方法,对button类进行了扩展,不太明白扩展方法的可以查下资料,简单来说即是给button类新增了个方法
//注意button是javafx包的fun button.isfastclick(): boolean { val lastclicktime = urdata a女生当兵的要求s long? val currenttime = system.currenttimemillis() urdata = currenttime //这里我设置为1s内多次点击无效,可以根据需要调整 if (lastclicktime != null && currenttime - lastclicktime <= 1000) { return true } return fal}
使用:
button{ action { //不是快速点击才进入点击逻辑 if (!isfastclick()) { println("hello") } }}
稍微重新封装了下,使用更加优雅
/** * 是否快速点击 */fun button.isfastclick(time:long): boolean { val lastclicktime = urdata as long? 上班族适合的兼职副业 val currenttime = system.currenttimemillis() urdata = currenttime if (lastclicktime != null && currenttime - lastclicktime <= time) { return true } return fal}/** * 设置防抖的按钮action * @param time 单位毫秒,默认1000(1s内防抖) */fun 我爱春天button.tactionhank(time:long = 1000,op: () -> unit) { action { if (!isfastclick(time)) { op() } }}
使用:
button("测试") { //这里不用action了 tactionhank{ println("111") }}
ps:后续会收录到common-controls的库中
class buttonutils { public static boolean isfastclick(button button) { object urdata = button.geturdata(); 专转本难吗 long currenttime = system.currenttimemillis(); button.turdata(currenttime); if (urdata instanceof兴趣爱好的英文 long) { long lastclicktime = (long) urdata; return currenttime - lastclicktime <= 1000; } return fal; }}
测试效果
到此这篇关于javafx 实现按钮防抖功能的文章就介绍到这了,更多相关javafx 按钮防抖内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-04 17:34:59,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/1a7df312f7dfbc074d5afc16d6a2202c.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:JavaFx 实现按钮防抖功能.doc
本文 PDF 下载地址:JavaFx 实现按钮防抖功能.pdf
留言与评论(共有 0 条评论) |