Project Icon

rofimoji

基于rofi的多功能Unicode字符选择工具

rofimoji是一款基于rofi的Unicode字符选择工具,支持表情符号和其他Unicode字符。该工具提供模糊搜索功能,能够记录常用字符,并允许自定义字符文件。用户可以灵活地插入或复制所选字符,同时支持配置表情符号的肤色。rofimoji兼容X11和Wayland环境,可与多种选择器集成。作为一个功能丰富的字符输入工具,rofimoji适合需要频繁使用特殊字符的场景。

Rofimoji: 一个用于 rofi 的字符选择器

你想使用那些花哨的表情符号吗?或者 Unicode 提供的其他有趣字符?但你还没找到一个好用的选择器?

不用担心,rofimoji 借助 rofi(以及其他 dmenu 衍生工具)的力量,为你提供一个你一直想要的选择器。

主要特性

它看起来如何?

默认样式

rofimoji 的截图

使用网格主题

使用网格主题的 rofimoji 截图

使用方法

独立运行

rofimoji 作为独立工具调用。

  1. 运行 rofimoji
  2. 搜索你想要的字符
  3. (可选)使用 shift+enter 选择多个表情符号
  4. enter 执行默认操作,或使用快捷键执行其他操作。
    alt+1 直接选择最近使用的字符(alt+2 选择第二常用的字符,以此类推)
  5. 可能需要选择肤色
  6. 🦾

作为 rofi 模式

rofimoji 集成为 rofi 的一种模式。

  1. 使用 rofi -modi "emoji:rofimoji" -show emoji 调用 rofi
  2. 搜索你想要的字符
  3. enter 执行默认操作;
    Alt+Shift+1 复制到剪贴板
    Alt+Shift+3 使用"剪贴板"插入方法
    alt+1 插入最近使用的字符(alt+2 插入第二常用的字符,以此类推)
  4. 可能需要选择肤色
  5. 🐉

rofimoji 作为 rofi 模式运行的注意事项

这种方法有一些限制: 作为 rofi 模式运行有几个无法改变的缺点:

  • 由于 rofi 是主进程,rofimoji 无法直接向任何窗口输入。只能复制字符,所以要相应地设置 --action
  • 一次只能选择一个字符。
  • 自定义键盘快捷键仍然存在,但映射到 Alt+Shift+1(在 Qwerty 键盘上)等。

配置仍然按照描述的方式工作。例如,你可以在 combi 中设置多个模式以用于不同的字符集,或设置默认操作和肤色。

配置

你可以通过命令行参数或配置文件 $XDG_CONFIG_HOME/rofimoji.rc 来配置 rofimoji。对于配置文件,使用不带双横线的长选项名称。

选项

长选项短选项可能的值默认值描述
--action-atype, copy, clipboard, unicode, copy-unicode, print, menutype选择 rofimoji 应该对所选字符执行的操作。详见下方的操作部分。
--files-fall<yourfile>data 目录中的任何文件emojis定义从哪些文件加载字符。对于已分发的文件或 ${XDG_DATA_HOME}/rofimoji/data 中的文件,不带扩展名的文件名(如 emojis_smileys_emotion)就足够了。可以使用 * 进行通配。all 是一次性加载所有默认文件的快捷方式。谨慎使用,这会加载大量文件。
--skin-tone-slight, medium-light, moderate, dark brown, black,以及 neutralaskask定义支持肤色的表情符号的肤色。ask 将始终询问用户。
--max-recent0-1010最多显示这么多最近选择的字符。数量上限为 10。设为 0 可禁用此功能。
--no-frecency
(配置文件中为 no-frecency=True
-<false>默认情况下,rofimoji 会首先显示常用项目。启用此选项后,它们将按文件中的顺序显示。
--hidden-descriptions
(配置文件中为 hidden-descriptions=True
-<false>仅列出字符,不显示其描述。这对 rofi网格主题很有用。请注意,即使不显示描述,仍然可以搜索到它们。不适用于其他选择器。
--use-iconsfalserofi 中将字符显示为图标。不适用于其他选择器。
--prompt-r任意字符串😀 定义 rofimoji 的提示文本。
--selector-args定义 rofimoji 将传递给选择器的参数。
请注意,由于 argparse 中的一个 bug,您需要将其指定为 --selector-args="<selector-args>"--selector-args " <selector-args>"
--selectorrofi, wofi, fuzzel, dmenu, tofi, bemenu, wmenu(自动选择)使用此应用程序显示选择对话框。
--clipboarderxsel, xclip, wl-copy(自动选择)使用此应用程序访问剪贴板。
--typerxdotool, wtype(自动选择)使用此应用程序输入字符。
--keybinding-copy, --keybinding-type, --keybinding-clipboard, --keybinding-unicode, --keybinding-copy-unicodeAlt+c, Alt+t, Alt+p, Alt+u, Alt+i选择不同于默认值的键绑定。

示例配置文件

~/.config/rofimoji.rc:

action = copy
files = [emojis, math]
skin-tone = moderate

操作

--action-a)选项定义选择字符时要执行的操作。可以用空格分隔指定多个操作(例如:-a type copy)。 选项如下:

名称快捷键描述
typealt+t直接将字符输入到最后活动的窗口中。这是默认操作
copyalt+c将字符复制到剪贴板。
clipboardalt+p通过从剪贴板粘贴来插入所选字符,而不是直接输入。参见插入方法
unicodealt+u输入所选字符的 Unicode 码点。
copy-unicodealt+i将码点复制到剪贴板。
print将选择的字符打印到 stdout

插入方法

默认情况下,rofimoji 使用 xdotoolwtype 输入字符(参见显示服务器支持)。您可以使用 --action type-a type)强制执行此行为。 对于某些应用程序(例如Firefox),这种方法可能不太可靠。为了解决这个问题,rofimoji可以将表情复制到剪贴板,然后通过shift+insert从剪贴板插入。之后,它会恢复之前的剪贴板内容。 不幸的是,接收应用程序是否使用剪贴板或主选择取决于应用程序本身。 因此,rofimoji同时使用两者,并恢复两者。 要使用这种解决方法,你可以使用快捷键alt+p或者以rofimoji --action clipboard-a clipboard)的方式启动。 如果你想直接输入而不是复制,即使以--action clipboard启动,你也可以按alt+t。请注意,你可以更改快捷键

最后,使用--action copy(或-a copy)可以让rofimoji只将选定的字符复制到剪贴板。

显示服务器支持

rofimoji通过使用适合每种环境的正确工具来支持X11和Wayland(参见支持的选择器)。它会尝试自动为当前运行的会话选择正确的工具。 如果你想手动覆盖此设置,请查看--selector--clipboarder--typer选项上文

最近使用的字符

默认情况下,rofimoji会单独显示最近使用的十个字符;你可以使用alt+1alt+2等插入它们。它将使用默认的插入方法。 如果你不想要这个功能,可以将--max-recent设置为0

此外,rofimoji还会记住哪些字符使用频率更高,并相应地对列表进行排序。你可以使用--no-frecency禁用此行为。

Rofi主题

默认情况下,rofimoji重用现有的rofi配置,但你可以使用--selector-args传递自己的配置(例如--selector-args="-theme ~/your-rofi-theme.rasi")。

如果你想要一个更注重字符的主题,可以使用打包的grid.rasi--hidden-descriptions参数一起使用。这个主题仍然导入现有的rofi配置,但将条目移到一个网格中。当然,你也可以基于此创建自己的主题。(如果你有改进,请开启PR!) 要在rofi中仅使用方向键控制网格而非查询,请传递这些-selector-args-kb-row-left Left -kb-row-right Right -kb-move-char-back Control+b -kb-move-char-forward Control+f

使用网格主题的rofimoji截图

支持的字符

如果你发现缺少什么,请开启一个issue!

自定义字符文件和描述

如果预定义的不够用,你可以定义额外的字符文件,并使用-f加载它们(参见选项)。每行可以定义一个"字符",后跟一个空格字符( )。之后,你可以写任何你想要的描述。

如果字符也在其他选定的文件中,所有描述将被合并。如果你给它与rofimoji包含的文件相同的名称,你的文件将被优先使用。

为了增加便利性,rofimoji会自动加载预定义文件的"附加"文件。这个文件需要命名为<filename>.additional.csv并位于${XDG_DATA_DIR}/rofimoji/data/中。例如,如果你想扩展emojis_smileys_emotion,将文件命名为emojis_smileys_emotions.additional.csv。这对于添加额外描述很有帮助:你可以定义这样一个附加字符文件,添加字符和你的描述,然后你的描述也会被显示。

如果你认为你的文件对其他人有用,请开启PR将其包含在rofimoji的未来版本中。

安装

从发行版仓库

打包状态

从PyPI

rofimojiPyPI上。你可以使用pipx install rofimoji(或sudo pipx install rofimoji)安装它。

从Github

下载最新发布版本的wheel文件,并使用sudo pip install $filename安装它(或者你可以使用pip install --user $filename仅为本地用户安装)。 之后,你的$PATH中应该有一个rofimoji。 这也会安装Python依赖configargparse

依赖项

你还需要什么:

  • Python 3.8 或更高版本
  • 能够显示你的脚本的字体(对于表情符号,EmojiOneNoto Emoji 可用)
  • 可选:用于将字符以编程方式输入应用程序的工具。X11 系统可用 xdotool,Wayland 系统可用 wtype
  • 可选:用于将字符复制到剪贴板的工具。X11 系统可用 xselxclip;Wayland 系统可用 wl-copy

支持的选择器

请注意,目前只有 rofi(在 X 和 Wayland 上都支持)支持自定义键盘快捷键、最近使用的文件或网格主题。对于其他选择器,仅基本功能可用。

X.org

Wayland

项目侧边栏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号