tray-icon lets you create tray icons for desktop applications.
Platforms supported:
- Windows
- macOS
- Linux (gtk Only)
Platform-specific notes:
- On Windows and Linux, an event loop must be running on the thread, on Windows, a win32 event loop and on Linux, a gtk event loop. It doesn't need to be the main thread but you have to create the tray icon on the same thread as the event loop.
- On macOS, an event loop must be running on the main thread so you also need to create the tray icon on the main thread.
Cargo Features
common-controls-v6
: UseTaskDialogIndirect
API fromComCtl32.dll
v6 on Windows for showing the predefinedAbout
menu item dialog.libxdo
: Enables linking tolibxdo
which is used for the predfinedCopy
,Cut
,Paste
andSelectAll
menu item, see https://github.com/tauri-apps/muda#cargo-featuresserde
: Enables de/serializing derives.
Dependencies (Linux Only)
On Linux, gtk
, libxdo
is used to make the predfined Copy
, Cut
, Paste
and SelectAll
menu items work and libappindicator
or libayatnat-appindicator
are used to create the tray icon, so make sure to install them on your system.
Arch Linux / Manjaro:
Debian / Ubuntu:
Examples
Create a tray icon without a menu.
use TrayIconBuilder;
let tray_icon = new
.with_tooltip
.with_icon
.build
.unwrap;
Create a tray icon with a menu.
use ;
let tray_menu = new;
let tray_icon = new
.with_menu
.with_tooltip
.with_icon
.build
.unwrap;
Processing tray events
You can use TrayIconEvent::receiver
to get a reference to the TrayIconEventReceiver
which you can use to listen to events when a click happens on the tray icon
use TrayIconEvent;
if let Ok = receiver.try_recv
You can also listen for the menu events using MenuEvent::receiver
to get events for the tray context menu.
use ;
if let Ok = receiver.try_recv
if let Ok = receiver.try_recv
Note for winit or tao users:
You should use [TrayIconEvent::set_event_handler
] and forward
the tray icon events to the event loop by using EventLoopProxy
so that the event loop is awakened on each tray icon event.
Same can be done for menu events using [MenuEvent::set_event_handler
].
let event_loop = with_user_event.build.unwrap;
let proxy = event_loop.create_proxy;
set_event_handler;
let proxy = event_loop.create_proxy;
set_event_handler;
License
Apache-2.0/MIT