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

Platforms supported:

Platform-specific notes:

Cargo Features

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:

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

Debian / Ubuntu:

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

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 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

```rs use tray_icon::TrayIconEvent;

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

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

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

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

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

License

Apache-2.0/MIT