Project Icon

keyd

灵活高效的Linux系统级键盘重映射工具

keyd是一个系统级Linux键盘重映射工具,使用内核级输入机制实现高效重映射。它支持自定义图层、按键重载、键盘特定配置等功能,可实现类似QMK固件的效果。keyd采用简洁配置,支持实时重映射,并提供客户端-服务器模型便于脚本和应用程序重映射。适合需要自定义键盘布局或在同一设备使用多种键盘的用户。

Kofi

动力

打包状态

Linux缺乏一个好的按键重映射解决方案。为了达到满意的效果,需要使用多种工具(如xcape、xmodmap),最终结果往往局限于特定环境(X11)。keyd试图通过提供一个灵活的全系统守护进程来解决这个问题,该守护进程使用内核级输入原语(evdev、uinput)重新映射按键。

关于v2的说明

自首次发布以来,配置格式经历了几次迭代。对于从v1迁移配置的用户,最好重新阅读手册页。

另请参阅:更新日志

目标

  • 速度(用C语言编写的手动调优输入循环,耗时<<1ms)
  • 简单性(直观的配置格式
  • 一致性(默认情况下,与层正常配合的修饰键)
  • 模块化(通过使用IPC机制可扩展的UNIX风格核心)

特性

keyd具有几个独特的功能,其中许多传统上只在自定义键盘固件如QMK中才能找到,还有一些是keyd独有的。

一些更有趣的功能包括:

  • 层(支持混合修饰键)。
  • 按键重载(点击/按住不同行为)。
  • 特定键盘配置。
  • 即时重映射(不再需要刷写:))。
  • 便于脚本编写和显示服务器无关的应用程序重映射的客户端-服务器模型。(目前支持X、sway和gnome(wayland))。
  • 全系统配置(在VT中也可工作)。
  • 对修饰键重载的一流支持。
  • Unicode支持。

keyd适合以下人群:

  • 想要尝试自定义(即自定义shift键)和单次修饰键的人。
  • 想在同一台机器上使用多个具有不同布局的键盘的人。
  • 想重新映射C-1而不破坏修饰键语义的人。
  • 想要易于理解的键盘配置格式的人。
  • 喜欢遵循Unix哲学的小型守护进程的人。
  • 想把控制键和Esc键放在上帝本来就想放的地方的人。
  • 希望能够切换到VT调试某些东西而不破坏键盘映射的人。

keyd不是:

  • 一个用于编程单个按键按下/松开事件的工具。

依赖项

  • 您喜欢的C编译器
  • Linux内核头文件(大多数系统上已存在)

可选

  • python(用于应用程序特定的重映射)
  • python-xlib(仅用于X支持)
  • dbus-python(仅用于KDE支持)

安装

*注意:*master分支作为开发分支,在发布版本之间可能偶尔会出现问题。发布版本会被标记,应被视为稳定版。

从源代码安装

git clone https://github.com/rvaiya/keyd
cd keyd
make && sudo make install
sudo systemctl enable keyd && sudo systemctl start keyd

快速入门

  1. 安装并启动keyd(例如sudo systemctl enable keyd

  2. /etc/keyd/default.conf中添加以下内容:

[ids]

*

[main]

# 将大写锁定键映射为按下时为Esc,按住时为Ctrl。
capslock = overload(control, esc)

# 将Esc键重新映射为大写锁定
esc = capslock

可以使用keyd monitor命令获取按键名称。请注意,当keyd运行时,此命令的输出将对应于keyd的输出。可以通过先停止keyd然后运行该命令来查看原始输入事件。有关更多详细信息,请参阅手册页。

  1. 运行sudo keyd reload重新加载配置集。

  2. 查看手册页(man keyd)以获取更全面的说明。

配置错误将出现在日志输出中,可以使用系统的服务管理器以通常的方式访问(例如sudo journalctl -eu keyd)。

注意:错误的配置文件可能会导致您的机器无法使用。如果您发现自己处于这种情况,特殊按键序列backspace+escape+enter应该会导致keyd终止。

一些鼠标(如罗技MX Master)能够发出按键信号,因此会被通配符ID匹配。可能需要显式地将这些设备列入黑名单。

应用程序特定重映射(实验性)

  • 将自己添加到keyd组:

    usermod -aG keyd <用户名>

  • 填写~/.config/keyd/app.conf

例如

[alacritty]

alt.] = macro(C-g n)
alt.[ = macro(C-g p)

[chromium]

alt.[ = C-S-tab
alt.] = macro(C-tab)
  • 运行:

    keyd-application-mapper

除非您正在运行Gnome,否则您可能想在显示服务器初始化逻辑中(例如~/.xinitrc)添加keyd-application-mapper -d

有关更多详细信息,请参阅手册页。

单板计算机支持

通过usb-gadget对单板计算机(SBC)的实验性支持已经添加,由Giorgi Chavchanidze提供。

详情请参见usb-gadget.md

软件包

一些发行版也存在第三方软件包。如果您希望将您的软件包添加到列表中,请提交PR。这些软件包由社区成员维护,我们不对其承担个人责任。

Alpine Linux

keyd软件包由@jirutka维护。

Arch

Arch Linux软件包由Arch打包者维护。

Debian

实验性的keydkeyd-application-mapper软件包可以在正在进行中的Debian软件包仓库的CI构建工件中找到:

Fedora

COPR软件包由@alternateved维护。

openSUSE

opensuse软件包由@bubbleguuum维护。

使用sudo zypper in keyd可轻松安装。

Ubuntu

实验性的keydkeyd-application-mapper软件包可在ppa:keyd-team/ppa存档中找到。

如果您希望帮助维护此PPA,请联系@rhansen

示例配置

[ids]

*

[main]

leftshift = oneshot(shift)
capslock = overload(symbols, esc)

[symbols]

d = ~
f = /
...

推荐配置

许多用户可能对充分利用keyd不感兴趣。对于那些寻求简单生活质量改善的人,我推荐以下配置:

[ids]

*

[main]

shift = oneshot(shift)
meta = oneshot(meta)
control = oneshot(control)

leftalt = oneshot(alt)
rightalt = oneshot(altgr)

capslock = overload(control, esc)
insert = S-insert

这将重载大写锁定键,使其同时具有Escape(轻击时)和Control(按住时)的功能,并将所有修饰键重新映射为"一次性"键。因此,要输出字母A,您现在只需轻击Shift然后按a,而不必一直按住它。最后,它将插入键重新映射为S-insert(在X11上粘贴)。

常见问题

xmodmap/setxkbmap/*呢?

xmodmap及类似工具是显示服务器级别的工具,功能有限。keyd是一个系统级解决方案,实现了高级功能,如分层和一次性修饰键。虽然一些X工具提供类似功能,但我不知道有什么比keyd更灵活的工具。

kmonad呢?

keyd是几年前编写的,目的是让我能够在我不断增长的键盘收藏上轻松尝试不同的布局。当时kmonad还不存在,像QMK这样的自定义键盘固件(启发了keyd)是获得类似功能的唯一方式。我在发布keyd后才知道kmonad。虽然kmonad是一个不错的项目,有类似的目标,但它采用了不同的方法和设计理念。

值得注意的是,keyd完全用C语言编写,考虑到性能和简单性,可能永远不会像kmonad(可用Haskell扩展)那样可配置。话虽如此,它在不到2000行C代码中提供了(作者认为)最有价值的功能,同时提供了简单的语言无关的配置格式。

为什么keyd不实现功能X?

如果您觉得缺少什么或发现bug,欢迎在github上提出问题。keyd有一个极简主义(但合理的)设计理念,有意省略某些功能(例如以root身份执行任意可执行文件)。已存在于QMK等自定义键盘固件中的功能是很好的包含候选。

贡献

参见CONTRIBUTING。 IRC频道:oftc上的#keyd

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号