有没有办法用 PyGTK AppIndicator

问题描述

我有一个简单的 Python 代码,它使用 AppIndicator3 中的 GI 创建 Linux 托盘指示器。这很好用。但我想检测和处理简单的用户点击或双击此托盘图标。

据我所知,例如 Telegram uses Qt class QSystemTrayIcon,它支持功能,因为当用户双击托盘图标时,Telegram 窗口会自行显示

  • 我知道 AppIndicator3 支持 scroll_event 信号,当用户在托盘图标上滚动鼠标滚轮时会触发该信号。

AyatanaAppIndicator3.Indicator 收到滚动事件时发出信号。

设置 menuitem 在二次激活事件时激活 (即中键单击)在 AyatanaAppIndicator3.Indicator 图标/标签

有人了解它是如何工作的吗?前面的两个例子让我想知道为什么没有简单的鼠标点击信号/事件。我在想是否有可能更深入,也许继承 AyatanaAppIndicator3.Indicator 类并重写一些事件处理?或者更深入地研究 StatusNotifierItemActivate 方法,如果它是 AppIndicator 实现的?

或者是否有任何棘手解决方法?因为这似乎是一个十多年没有答案的问题,我对“不可能”的回答不满意。

我也知道我不是第一个问这个问题的人。我做了一些小调查,发现了多个相关主题

Python AppIndicator bindings -> howto check if the menu is open?
How to run an action when clicking on an appindicator
How to program a one click indicator (add middle click functionality)?
indicator-application does not send signals when a menu is shown/hidden
handle click events and modifiers

解决方法

AppIndicator 的感知限制是有意的设计选择(请参阅背景信息)。

监听鼠标点击事件不起作用

通过 AppIndicator,您可以进行以下交互:

  • 主要操作:显示上下文菜单(可能仅包含常规菜单项,不能放置任意小部件)。
  • 次要操作:激活此上下文菜单中的一个特定项目(通常在桌面上单击鼠标中键)。
  • 监听图标上的鼠标滚动事件。

您需要切换到另一种检测任意鼠标点击的解决方案。在这里,我假设您想在相应地标记问题时坚持使用 Python/GTK。

一种解决方案是使用基于相当古老的 System Tray Protocol Specification 的 Gtk.StatusIcon。问题是这个解决方案正在慢慢被淘汰。它在 GTK3 中被标记为弃用,并在 GTK4 中被移除。

我所知道的唯一其他可行的解决方案是 libxapps(由 Mint Linux)。它具有 XApp.StatusIcon,专门设计为 Gtk.StatusIcon 的现代替代品。它支持所有可以显示托盘图标的桌面环境。

背景信息

Ubuntu 桌面体验团队将 Linux 桌面通知区域视为“问题区域”。他们具体批评了不同应用状态图标在用户体验和风格上的不一致。他们提议将用户交互限制为几种标准化方式。这一努力导致了 AppIndicator 的发展。 (Source)

顺便说一下,这是另一篇关于不同解决方案的旧博文(2011 年):
StatusNotifierItem (aka App Indicators) for Qt applications