| Crates.io | tauri-plugin-wallpaper |
| lib.rs | tauri-plugin-wallpaper |
| version | 3.0.0 |
| created_at | 2023-03-29 20:27:25.37307+00 |
| updated_at | 2026-01-23 08:44:23.853879+00 |
| description | A Tauri plugin to set your window as wallpaper behind desktop icons |
| homepage | https://github.com/meslzy/tauri-plugin-wallpaper |
| repository | https://github.com/meslzy/tauri-plugin-wallpaper |
| max_upload_size | |
| id | 824372 |
| size | 148,997 |
A Tauri plugin for advanced window positioning on Windows desktop
Embed your window behind desktop icons - perfect for creating animated wallpapers, desktop widgets, or background applications.
attach - Places window behind desktop icons (wallpaper layer)detach - Restores window to normal behaviorreset - Resets the desktop wallpaperKeep your window always on top and make it survive Win+D (Show Desktop) - perfect for overlay apps, sticky notes, or always-visible tools.
pin - Window stays on top and ignores Show Desktop (Win+D)unpin - Restores normal window behaviorWindows Only - This plugin uses Win32 APIs for desktop integration.
| Platform | Support |
|---|---|
| Windows | Full |
| macOS | None |
| Linux | None |
# Rust
cargo add tauri-plugin-wallpaper
# JavaScript/TypeScript
npm install tauri-plugin-wallpaper
use tauri_plugin_wallpaper::{WallpaperExt, AttachRequest, PinRequest};
#[cfg_attr(mobile, tauri::mobile_entry_point)]
pub fn run() {
tauri::Builder::default()
.plugin(tauri_plugin_wallpaper::init())
.setup(|app| {
let handle = app.handle();
// Wallpaper mode - window goes behind desktop icons
handle.wallpaper().attach(AttachRequest::new("window_label"))?;
handle.wallpaper().detach(DetachRequest::new("window_label"))?;
handle.wallpaper().reset()?;
// Pin mode - window stays on top, survives Win+D
handle.wallpaper().pin(PinRequest::new("window_label"))?;
handle.wallpaper().unpin(UnpinRequest::new("window_label"))?;
Ok(())
})
.run(tauri::generate_context!())
.expect("error while running tauri application");
}
import { attach, detach, reset, pin, unpin } from "tauri-plugin-wallpaper";
// Wallpaper mode - window goes behind desktop icons
await attach("window-label"); // or attach() for current window
await detach("window-label");
await reset();
// Pin mode - window stays on top, survives Win+D
await pin("window-label"); // or pin() for current window
await unpin("window-label");
Add to your Tauri capabilities config:
{
"permissions": [
"wallpaper:default"
]
}
See permissions reference for granular permissions.
Uses the Windows WorkerW technique to parent your window under the desktop's WorkerW layer, placing it behind icons but above the actual wallpaper.
Subclasses the window procedure to intercept WM_WINDOWPOSCHANGING messages. When Win+D attempts to move the window to (-32000, -32000), the move is blocked, keeping the window visible.
If you're building something beyond a hobby project, consider implementing the Win32 logic directly in your application rather than depending on this library. The core techniques are documented in the How It Works section and the source code is straightforward to adapt.
This gives you full control over the implementation and avoids dependency on a library that may not be actively maintained.
MIT