首页 > 后端开发 > Python教程 > 构建桌面启动器

构建桌面启动器

DDD
发布: 2024-12-07 07:57:12
原创
512 人浏览过

我仍然在我的 Mac 上使用 QuickSilver,尽管有多种努力试图取代它。曾经有一款针对 Linux 的软件,名为 Gnome Do,但开发最终停止了。我选择了 Gnome Shell 中的内置启动器,然后短暂地使用此配置转向 rofi。

我非常喜欢 Quicksilver 的一件事是我可以在某种程度上将一个操作的结果“管道”到另一个操作,例如:

Building a desktop launcher
快银中的“管道”正在运行

例如,我可以首先查找文件 DSCF8200.jpg,然后选择“打开方式”操作,然后选择应用程序预览。这是 rofi 和 Gnome Shell 无法提供的灵活性。

另外,我什至无法让 rofi 在 Wayland 会话中运行。

找工作看起来仍然是一个漫长的过程(是的,这里仍然是#OpenToWork),只是为了分散我的注意力,我决定开始开发一个我最终会开始使用的简单启动器。这次我也想借此机会学习如何真正构建一个 GUI 应用程序。

考虑到我对 Python 最熟悉,我从 tkinter 开始。不过,我会从小事做起,并使用 CLI 命令开始实验。命令的构建,将作为启动器的蓝图。

RapidCopper 就是这样开始的(抱歉,这个名字缺乏想象力)。

是的,我知道 tkinter GUI 应用程序目前无法在 Wayland 中运行。

它仍处于非常早期的阶段,我仍在制作原型,并且仍在确定启动器的规格。不过,目前它已经完成了我想要它做的事情。

应用程序仍需要设置,

rc rebuild-index
登录后复制

这会在 $HOME/.config/rapidcopper 中设置配置,以 sqlite3 数据库作为索引,以及一个插件文件夹。

do 子命令是它执行其工作的部分。我可以启动应用程序

rc do fire
登录后复制

它会输出一个选项列表

0 app: /home/jeffrey04/.local/share/applications/userapp-Firefox Developer Edition-EPEGV2.desktop - Custom definition for Firefox Developer Edition
                Firefox Developer Edition
1 app: /home/jeffrey04/.local/share/applications/firefox-developer.desktop - Firefox Aurora with Developer tools
                Firefox Developer Edition
2 app: /home/jeffrey04/.local/share/applications/userapp-Firefox Developer Edition-8CCQV2.desktop - Custom definition for Firefox Developer Edition
                Firefox Developer Edition
Enter choice: :
登录后复制

输入一个数字,按回车键,相应的应用程序启动(通过gtk-launcher,是的,这个脚本不可移植)。

我想在某种程度上复制水银的用户体验,所以我让它知道管道字符 |,尽管它在实践中看起来很难看。

rc do echo lorem ipsum dolor sit amet "|" clipboard
登录后复制

指定的文本 lorem ipsum dolor sat amet 将被复制到剪贴板。不幸的是,我必须用引号将管道字符括起来,这样它就不会在 shell 中被视为重定向。

我仍在研究用户体验和规范,但现在它完成了我希望它启动应用程序的主要任务。在花了一些时间之后,我想起了 Textual,它提供了类似于 Web 前端开发的体验。目前,TUI 仍在开发中,但其工作原理似乎与 CLI 类似。

很难说我对此有何期望,因为我目前正在准备找一些临时兼职工作,同时寻找下一个项目。这将大大减少我留给该项目的时间和精力。启动器目前确实对插件有非常基本的支持,但 API 可能会发生变化。

以上是构建桌面启动器的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板