Fcitx5
Fcitx5 是一个输入法框架,它具有轻量级内核,并通过 addon 提供额外的语言支持。Fcitx5 接替 Fcitx。
安装[编辑 | 编辑源代码]
fcitx5-im包组 包组提供 fcitx5包 本体、#配置工具和必要的#输入法模块。
中文[编辑 | 编辑源代码]
- fcitx5-chewing包 是流行的繁体中文注音输入引擎,它基于 libchewing包。
- fcitx5-chinese-addons包 包含与中文相关的 addon,例如拼音、双拼和五笔。
- fcitx5-rime包 使用 Rime 引擎。
- fcitx5-mcbopomofo-gitAUR McBopomofo 支持。
日文[编辑 | 编辑源代码]
- fcitx5-anthy包 是流行的日文输入引擎。但是,它已不再受到积极开发。
- fcitx5-kkc包 是日文假名输入引擎,它基于 libkkc包。
- fcitx5-mozc包 基于 Mozc(Google 日文输入法的开源版本)。
- fcitx5-skk包 是日文假名输入引擎,它基于 libskk包。
其他语言[编辑 | 编辑源代码]
- fcitx5-hangul包 用于输入韩文,基于 libhangul包。
- fcitx5-unikey包 或 fcitx5-bamboo-gitAUR 可用于输入越南语字符。
- fcitx5-m17n包 或 fcitx5-table-other包 可用于各种语言。使用后者输入 IPA(X-SAMPA)。
输入法模块[编辑 | 编辑源代码]
要获取更好的体验,你可以根据需要安装以下模块。即使不安装,输入法在大部分的应用程序中仍可能正常工作,但你可能会遇到输入法挂起、预览窗口位置错误或没有预览的问题。
- 对于 Qt 程序,安装 fcitx5-qt包。
- 对于 GTK 程序,安装 fcitx5-gtk包。
- 对于 Qt4 程序,安装 fcitx5-qt4-gitAUR。
- 对于 Qt5 程序,安装 fcitx5-qt5-gitAUR。
- 对于 Qt6 程序,安装 fcitx5-qt6-gitAUR。
- 对于日期和时间支持,安装 fcitx5-lua包。
使用[编辑 | 编辑源代码]
集成[编辑 | 编辑源代码]
- 安装 fcitx5-input-supportAUR。
- 或者编辑
/etc/environment
并添加以下几行,然后重新登录[1]:
GTK_IM_MODULE=fcitx QT_IM_MODULE=fcitx XMODIFIERS=@im=fcitx SDL_IM_MODULE=fcitx GLFW_IM_MODULE=ibus
如果使用 en_US.UTF-8 时,遇到 GTK2 无法激活 fcitx5,可专门为该 GTK2 应用程序设置输入法为 xim,如
$ env GTK_IM_MODULE=xim <your_gtk2_application>
请勿将 GTK_IM_MODULE
全局设置为 xim,因为它也会影响 GTK3 程序。XIM 有各种问题(比如输入法重启之后再无法输入),尽可能不要使用。
- SDL_IM_MODULE 是为了让一些使用特定版本 SDL2 库的游戏能正常使用输入法。
- GLFW_IM_MODULE 是为了让 kitty 启用输入法支持。此环境变量的值只能为 ibus。
- 按 fcitx5 上游推荐,环境变量的值设置为
fcitx
。部分并非由 Arch 从源码编译打包的应用程序(如从 Telegram 官方网站下载的 telegram-desktop)因兼容性的需求而需要将之设置为fcitx5
。
随桌面环境自动启动[编辑 | 编辑源代码]
想要 fcitx5包 开机自启,执行
$ cp /usr/share/applications/org.fcitx.Fcitx5.desktop ~/.config/autostart/
如果使用 xinit 启动,则可以在~/.xinitrc
中,在exec
前添加fcitx5 &
词库[编辑 | 编辑源代码]
对于 Fcitx5 的中文输入法, 目前在仓库里提供了数个词库:
- fcitx5-pinyin-zhwiki包:felixonmars 根据中文维基百科创建的词库。适用于 拼音输入法
- fcitx5-pinyin-sougouAUR[损坏的链接:package not found]:适用于拼音输入法的搜狗词库
- rime-pinyin-zhwiki包:适用于 Rime 输入法的词库
- fcitx5-pinyin-moegirl-rimeAUR:适用于 Rime 输入法的词库
- cedict:从 cedict辞典 导出的词库。
- fcitx5-pinyin-moegirlAUR: outloudvi 根据萌娘百科创建的词库
自定义词库[编辑 | 编辑源代码]
一般而言,由于 fcitx5包 支持 导入搜狗词库,因此很大程度上不需要自定义词库,但是 fcitx5包 依然提供了相关工具。
- 安装 libime包
原始词库文件是一个文本文件,其格式为: 汉字 拼音 频率
在得到原始词库文件后,调用 libime_pinyindict "词库文件.txt" "词库文件.dict"
即可。
自定义词库文件放置在 ~/.local/share/fcitx5/pinyin/dictionaries
配置[编辑 | 编辑源代码]
配置工具[编辑 | 编辑源代码]
fcitx5包 的配置文件位于 ~/.config/fcitx5
,尽管您可以使用文本编辑器编辑配置文件,但是使用 GUI 配置显然更方便。安装 fcitx5-configtool包 软件包。
主题和外观[编辑 | 编辑源代码]
主题[编辑 | 编辑源代码]
仓库内的主题数量有限,如果需要更多主题,可以去 GitHub 发现更多主题。
- fcitx5-breezeAUR:提供了与KDE默认的Breeze主题匹配的外观。
- fcitx5-nord包 :Nord颜色 的主题
- fcitx5-material-color包:提供了类似微软拼音的外观。
- fcitx5-solarizedAUR:Solarized颜色 主题
- fcitx5-skin-fluentdark-gitAUR:具有模糊效果和阴影的 Fluent-Design 深色主题
然后前往 Fcitx5设置 -> 配置附加组件 -> 经典用户界面 -> 主题
设置主题。
设置单行模式[编辑 | 编辑源代码]
在拼音输入法(或者 Rime 输入法)的设置中,启用“ 在程序中显示预编辑文本 ”即可启用单行模式
故障处理[编辑 | 编辑源代码]
诊断问题[编辑 | 编辑源代码]
当你遇到任何 Fcitx 5 有关的问题,比如 Ctrl+Space 快捷键在有的程序中不能工作,首先应该用 fcitx5-diagnose
命令诊断问题的原因。
fcitx5-diagnose
会列出所有 Fcitx 5 正常运行所需的前提条件,从输出结果中通常可以找到问题的原因。
部分应用中 Fcitx 5 的单行默认无效[编辑 | 编辑源代码]
1. 如果是 Firefox 等 gtk 应用中单行模式不生效,请安装 fcitx5-gtk包
2. 在 WPS 和 Sublime 中单行模式无效,这是 WPS 和 Sublime 自身的问题,而不是 fcitx5包 的问题。[3]
WPS 无法正常呼出输入法[编辑 | 编辑源代码]
IntelliJ 系列软件的 IDE 中输入框位置不正确[编辑 | 编辑源代码]
此问题的根本原因是 IDE 附带的 JBR 不正确,要处理此问题,需要:
1. 前往 https://github.com/RikudouPatrickstar/JetBrainsRuntime-for-Linux-x64/releases 下载 jbr 并解压到任意路径
2. 按照 此指导 更改 IDE 的 JBR
Emoji 在候选框中无法正常显示[编辑 | 编辑源代码]
1. 首先确保电脑上已经安装了带有 Emoji 的字体(例如 noto-fonts-emoji包)。
2. 将字体设置为 Noto Sans CJK SC
3. 运行以下命令来 重启 Fcitx5
$ kill `ps -A | grep fcitx5 | awk '{print $1}'` && fcitx5&
RStudio 中无法调出输入法[编辑 | 编辑源代码]
运行以下命令:
$ strings /usr/lib/rstudio/lib/libQt5Core.so.5 | grep "Qt 5"
找出 Qt 库的版本,使用该版本重新编译 fcitx5-qt包 中的 libfcitx5platforminputcontextplugin.so
,再放到 /usr/lib/rstudio/plugins/platforminputcontexts/
目录中。
如果使用的是 rstudio-desktop-binAUR ,可直接安装 rstudio-fcitx5AUR 。
在 Steam 和 Dota2 中无法使用[编辑 | 编辑源代码]
事实上,Fcitx5 能够在 Steam 大屏模式和 Dota2 中使用。但是需要使用 Ctrl + Space 激活输入法而不是 Ctrl + Shift [4]
使用 Wayland 输入法协议的软件无法获取Wayland Popup窗口(Kde && Sway && Gnome)[编辑 | 编辑源代码]
指使用 Wayland 输入法协议的软件,比如 wezterm 、gtk 软件(如果环境变量指定为GTK_IM_MODULE=wayland
)。这些软件如果没有进行设置,到今天为止,你得到的输入法体验是看不见Popup窗口,但是可以盲输入是可以的,因为很多wm没有完全实现input-method-v2协议。
关于qt软件,gtk软件对于wayland支持,根据fcitx5开发者所说
- Qt 有 text-input-v2 支持,你可以使用它通过设置 QT_IM_MODULE 为空,但它有一些关于预编辑的小问题。 此外,对于当前版本的 wayland 输入法协议,wayland 只能有一个全局输入上下文(具体请参考原始文章), 所以现在如果你想使用 Fcitx 5 支持的“per-application”输入状态可能是个问题。但是使用 Qt 的文本输入协议有一个好处,就是输入窗口在视觉上不会闪烁。
- Gtk 有 text-input-v3 支持,但它的预编辑样式很差,粗体字体突出显示。此外,其surrounding text支持实现的很差。所以现在,如果您想拥有所有 Fcitx 功能,使用 GTK_IM_MODULE=fcitx 可能仍然是一个不错的选择。
KDE[编辑 | 编辑源代码]
如你所见,上文的连接贴出了当前kde环境下解决这个问题的方法,设置中开启fcitx5的虚拟键盘支持,设置中心搜索virtual keyboard, 选择fcitx5并且开启。
Sway[编辑 | 编辑源代码]
sway 已经合并了实现 text-input-v3 协议的分支,但是仍然没有完全实现 input-method-v2 协议,因此仍然无法显示弹出窗口。目前有一个开放的拉取请求可以修复此问题:https://github.com/swaywm/sway/pull/7226 ,可以在 AUR 上安装:sway-imAUR。
GNOME[编辑 | 编辑源代码]
Gnome 可以选择安装 kimpanel 插件。
提示和技巧[编辑 | 编辑源代码]
如何查看选中字体的 Unicode 编码[编辑 | 编辑源代码]
- 如果你需要查看文本编辑器中选中文字的 Unicode 编码,那么直接选中文字,然后使用快捷键
ctrl + alt + shift + u
可以查看选中文字的编码
- 如果你需要查看非编辑区域(比如本 wiki)中文字的 Unicode 编码,那么需要首先将该段文字复制到剪贴板,然后点击任意一个可编辑区域(比如搜索框),然后使用快捷键
ctrl + alt + shift + u
可以查看剪贴板中文字的编码
通过 Fcitx5 输入特殊字符[编辑 | 编辑源代码]
要输入特殊符号,有两种方式:
以 ①
为例:
将光标定位到任意一个输入框内,然后按下 Ctrl + Alt + Shift + U
,然后输入 circle one
,您将会看到多种形式的 ①
。alpha, beta, sigma 等同理。
在 vim 中自动切换输入法[编辑 | 编辑源代码]
推荐使用 fcitx.vim 插件。此插件会为不同缓冲区保持各自的插入模式输入法状态。
简单的方案,可以向 ~/.vimrc
追加代码:[2][3]
let fcitx5state=system("fcitx5-remote")
" 退出插入模式时禁用输入法,并保存状态
autocmd InsertLeave * :silent let fcitx5state=system("fcitx5-remote")[0] | silent !fcitx5-remote -c
" 2 表示之前状态打开了输入法,则进入插入模式时启动输入法
autocmd InsertEnter * :silent if fcitx5state == 2 | call system("fcitx5-remote -o") | endif
如果使用的是 neovim包 ,则追加上述代码到 ~/.config/nvim/init.vim
。
拼音输入法[编辑 | 编辑源代码]
导入搜狗词库[编辑 | 编辑源代码]
- 对于 KDE 用户来说,可以通过
设置 -> 区域设置 -> 输入法 -> 拼音 -> 词典 -> 导入
来导入搜狗词库
- 对于使用 fcitx5-configtool包 的用户来说,需要手动打开 “Fcitx5 配置” 这个软件,并在拼音输入法中手动配置。
既可以导入本地词库也可以在线浏览词库并自动导入
云拼音[编辑 | 编辑源代码]
在拼音输入法的设置页面,你可以启用云拼音。但是如果你需要更改云拼音默认的后端,则需要在 fcitx5包 的全局设置里进行更改。提供的后端有 Google
, Baidu
, GoogleCN
笔画过滤[编辑 | 编辑源代码]
在设置的拼音输入法的“笔画过滤”后设置快捷键(默认为 `
)
然后在输入文字后,按下快捷键,输入法的候选框将会出现 笔画过滤字样,可以对词语进行笔画过滤,具体规则为:h 横、s 竖、p 撇、n 捺、z 折
默认情况下,笔画过滤是对一个句子的第一个字进行筛选,但是使用以词定字可以在一个句子之间的不同字之间进行切换。
例如对句子“中华人民共和国”中的第三个字进行笔画筛选,你可以在启用笔画过滤后连续按两次 ]
让 fcitx5包 对其进行笔画过滤。
[
和 ]
,该快捷键在拼音输入法的设置中可以查看RIME/中州韻[编辑 | 编辑源代码]
导入词库[编辑 | 编辑源代码]
以导入词库fcitx5-pinyin-zhwiki-rimeAUR和fcitx5-pinyin-moegirl-rimeAUR为例.
~/.local/share/fcitx5/rime/
亦可,文件名(文件名.dict.yaml)应与词库名统一(词库格式)1.更改~/.local/share/fcitx5/rime/luna_pinyin.custom.yaml
文件(以luna_pinyin
为例,其余输入方案修改方案名即可)
~/.local/share/fcitx5/rime/luna_pinyin.custom.yaml
# 文件中“patch:”应只存在一个,若已存在只需粘贴后面的代码 # 此文件用于修改特定输入方案,把上方的luna_pinyin改为其它输入方案名即可完成对其它输入方案的修改 patch: "translator/dictionary": extended #词典名字可自定义,与下方文件名保持一致即可
2.新建~/.local/share/fcitx5/rime/extended.dict.yaml
文件
~/.local/share/fcitx5/rime/extended.dict.yaml
# 以下禁用了默认词库同时不启用默认的“八股文”词库及词频系统,如果您不希望候选词中的出现繁体字、方框字的话 --- name: extended version: "2021.02.19" sort: by_weight use_preset_vocabulary: false #是否启用默认的“八股文”词库及词频系统,如需启用请设为 true 。 import_tables: # - luna_pinyin #默认词库,如需启用请取消注释 - zhwiki - moegirl # - 自定义词库名 ...
模糊音设置[编辑 | 编辑源代码]
请根据需要注释(#)或删除不需要的模糊音,若需增加其它模糊音,请参考明月拼音模糊音定制模板
若luna_pinyin.custom.yaml
文件不存在
~/.local/share/fcitx5/rime/luna_pinyin.custom.yaml
patch: "speller/algebra": - derive/^([zcs])h/$1/ #zh,ch,sh->z,c,s - derive/^([zcs])([^h])/$1h$2/ #z,c,s->zh,ch,sh - derive/^n/l #n->l - derive/^l/n #l->n - derive/([ei])n$/$1ng/ # en -> eng, in -> ing - derive/([ei])ng$/$1n/ # eng->en, ing -> in - abbrev/^([a-z]).+$/$1/ #简拼支持 - abbrev/^([zcs]h).+$/$1/ #模糊音的简拼支持 delimiter: " '" #分隔符
如果文件存在,则粘贴patch:
以下的部分到文件末尾(luna_pinyin.custom.yaml
中有且只有一个patch:
)
特殊符号[编辑 | 编辑源代码]
导入rime-dict项目中symbols.dict.yaml
词库即可在拼音中输入希腊字母、部分数学符号及Emoji表情
示例:
希腊字母:输入alpha
即可输出α
数学符号:输入jifen
即可输出∫
特殊符号:输入cha
可输出✕,✖
序号:输入qi
可输出Ⅶ,⑦
Emoji表情:输入haha
可输出😃,😆
加载 librime-lua 插件[编辑 | 编辑源代码]
若想加载 librime-lua 插件,须在 fcitx 配置工具的 Rime 输入法设置中添加 lua
模块。