3 releases
new 0.1.2 | Dec 20, 2024 |
---|---|
0.1.1 | Dec 19, 2024 |
0.1.0 | Dec 19, 2024 |
#539 in GUI
71 downloads per month
59KB
1K
SLoC
tray-icon-win lets you create tray icons for desktop applications on Windows.
This is a personal fork of tray-icon. For general use, please consider using the original.
Notes:
- An event loop must be running on the thread, on Windows, a win32 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.
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.
Examples
Create a tray icon without a menu.
use tray_icon_win::TrayIconBuilder;
let tray_icon = TrayIconBuilder::new()
.with_tooltip("system-tray - tray icon library!")
.with_icon(icon)
.build()
.unwrap();
Create a tray icon with a menu.
use tray_icon_icon::{TrayIconBuilder, menu::Menu};
let tray_menu = Menu::new();
let tray_icon = TrayIconBuilder::new()
.with_menu(Box::new(tray_menu))
.with_tooltip("system-tray - tray icon library!")
.with_icon(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 tray_icon_win::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.
use tray_icon_win::{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);
}
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
.
enum UserEvent {
TrayIconEvent(tray_icon::TrayIconEvent)
MenuEvent(tray_icon::menu::MenuEvent)
}
let event_loop = EventLoop::<UserEvent>::with_user_event().build().unwrap();
let proxy = event_loop.create_proxy();
tray_icon_win::TrayIconEvent::set_event_handler(Some(move |event| {
proxy.send_event(UserEvent::TrayIconEvent(event));
}));
let proxy = event_loop.create_proxy();
tray_icon_win::menu::MenuEvent::set_event_handler(Some(move |event| {
proxy.send_event(UserEvent::MenuEvent(event));
}));
License
Dependencies
~11–19MB
~250K SLoC