加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

当用户按下可编辑的UI组件时,在Linux中自动启动键盘

发布时间:2020-12-14 02:02:00 所属栏目:Linux 来源:网络整理
导读:问题陈述: Linux环境中需要虚拟键盘,每次用户按下可编辑的UI组件时都应启动虚拟键盘,如iPhone,iPad,Android等虚拟键盘. 解决方案概述:作为虚拟键盘的基础是matchbox-keyboard,它是一个开源应用程序并提供丰富的功能.自动切换的机制通过修改QT和GTK的源来解
问题陈述: Linux环境中需要虚拟键盘,每次用户按下可编辑的UI组件时都应启动虚拟键盘,如iPhone,iPad,Android等虚拟键盘.

解决方案概述:作为虚拟键盘的基础是matchbox-keyboard,它是一个开源应用程序并提供丰富的功能.自动切换的机制通过修改QT和GTK的源来解决,以便在“on_press”信号上发送Dbus信号(当用户按下可编辑的UI comp时)到某个守护进程,该守护进程打开虚拟键盘.

问题:当用户按下或点击UI组件时,即在QT和GTK的“on_click”事件期间,发送“on_press”Dbus信号.虚拟键盘隐藏在QT和GTK的“focus_out”事件上.在“focus_in”事件期间键盘未打开,因为启动时某些应用程序发出“focus_in”事件片刻然后发出“focus_out”事件,因此虚拟键盘显示的时间很短,然后隐藏,这是不准确的.这是通过在“on_click”GTK和QT事件期间生成“on_press”Dbus信号来解决的.

所以现在我有另一个问题.

>让我们说用户按下了可编辑的盒子,出现了虚拟键盘,
“on_click”(GTK,QT事件) – > “on_press”(Dbus信号) – >虚拟键盘已启动
>然后用户按Tab键切换到其他可编辑框.
“focus_out”(GTK,QT事件) – > “hide_keyboard”(Dbus信号) – >虚拟键盘被隐藏,不会再次启动.

发生这种情况是因为第二个可编辑框发出“focus_in”事件而不是“on_click”事件.

因此,当用户在带有标签按钮的可编辑框之间切换时,请帮助找到解决方案.或者,如果您有完全其他解决方案,请提出建议.

提前致谢,
列翁

解决方法

我是佛罗伦萨虚拟键盘的作者: http://florence.sourceforge.net. 我使用at-spi(http://en.wikipedia.org/wiki/Assistive_Technology_Service_Provider_Interface)来解决问题. at-spi的优势在于它不仅适用于GTK和Qt,还适用于java,Firefox和Libre / OpenOffice.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读