我有一个 bash 脚本,它使用 打开一个窗口notify-send
。我想在脚本结束时关闭该窗口,但我找不到任何东西kill
。
该问题与https://askubuntu.com/questions/639754/is-it-possible-to-cancel-or-clear-a-notification-created-by-using-notify-send重复,但对我而言,这些答案都不起作用。公认的答案是终止一个名为 的进程notify-osd
,但我没有类似的东西。值得注意的是,这个问题已有十年历史了。
我的脚本就像
notify-send -u critical -i ~/.icons/my-icon.png "$titletext" "$helptext"
helppid=$!
…
kill $helppid
(紧急程度设置至关重要,以便帮助窗口保持打开状态直到明确关闭。)
问题是$!
没有返回值。ps -ef | grep -i notify
显示没有与我的脚本相关的任何内容。
我找到了一种解决方法,使用print-id
以下功能( https://askubuntu.com/a/161852notify-send
中描述):
print-id=$(notify-send -p -u critical -i ~/.icons/my-icon.png "$titletext" "$helptext")
notify-send -r $print-id -u low ~/.icons/my-icon.png "$titletext" Finished
有人能描述一种更好的方法来关闭帮助对话框吗?我已经阅读了 的建议yad
,不知道是否要安装并评估它。
您的解决方法听起来像是完美的解决方案。通常情况下, archlinux 会提供有关通知如何工作的更多信息;它们现在通常通过 实现在桌面上
dbus
。dbus
是一项后台服务,允许工具表示它们愿意提供具有众所周知名称的某些功能,例如通知弹出窗口的“org.freedesktop.Notifications”。当应用程序notify-send
想要显示通知时,它会通过 dbus 向该功能的众所周知名称发送一条消息,然后侦听工具会执行预期的操作,并发回通知的 ID 以供将来使用。这就是如何
notify-send
几乎立即返回,并且您看不到新进程正在运行;通常,提供该功能的工具倾向于一直作为守护进程运行,或者作为某些较大的桌面代码的一部分运行。dbus
如果它尚未监听消息,也可以配置为“按需”启动该工具。因此,下拉通知的最简洁方法是传递相同的 API,并使用
notify-send
新状态更新上一个通知。这不需要您知道提供弹出窗口的工具(如果有),因此是最面向未来的。