tray-icon lets you create tray icons for desktop applications.

Platforms supported:

Platform-specific notes:

Cargo Features

Dependencies (Linux Only)

On Linux, gtk and libappindicator or libayatnat-appindicator are used to create the tray icon, so make sure to install them on your system.

Arch Linux / Manjaro:

sh pacman -S gtk3 libappindicator-gtk3 #or libayatana-appindicator

Debian / Ubuntu:

sh sudo apt install libgtk-3-dev libappindicator3-dev #or libayatana-appindicator3-dev

if you use tray_icon::muda module, make sure to checkout https://github.com/tauri-apps/muda#dependencies

Examples

Create a tray icon without a menu.

```rs use tray_icon::TrayIconBuilder;

let trayicon = TrayIconBuilder::new() .withtooltip("system-tray - tray icon library!") .with_icon(icon) .build() .unwrap(); ```

Create a tray icon with a menu.

```rs use tray_icon::{TrayIconBuilder, menu::Menu};

let traymenu = Menu::new(); let trayicon = TrayIconBuilder::new() .withmenu(Box::new(traymenu)) .withtooltip("system-tray - tray icon library!") .withicon(icon) .build() .unwrap(); ```

Processing tray events

You can use TrayEvent::receiver to get a reference to the TrayEventReceiver which you can use to listen to events when a click happens on the tray icon

```rs use tray_icon::TrayEvent;

if let Ok(event) = TrayEvent::receiver().try_recv() { println!("{:?}", event); } ```

You can also listen for the menu events using TrayEvent::receiver to get events for the tray context menu.

```rs use tray_icon::{TrayEvent, menu::{MenuEvent}};

if let Ok(event) = TrayEvent::receiver().try_recv() { println!("tray event: {:?}", event); }

if let Ok(event) = MenuEvent::receiver().try_recv() { println!("menu event: {:?}", event); } ```

License

Apache-2.0/MIT