tauri:关闭窗口后最小化到托盘

上一篇博客记录了一个最简单的tauri+vue3+vite案例,这篇博客来实现关闭窗口后最小化到托盘的功能,注意我这里使用的是tauri2.0,与tauri1.0的托盘实现区别很大。

1、创建托盘

在Cargo.toml文件的tauri配置里添加tray-icon.

在src-tauri的src下创建tray.rs文件,代码如下:

注意:

use tauri::{

menu::{Menu, MenuItem}, tray::TrayIconBuilder, AppHandle, Manager, Runtime

};这里面的Manager看似没用到,其实在app.get_webview_window的时候会用到,不能删除。

rust 复制代码
use tauri::{
    menu::{Menu, MenuItem}, tray::TrayIconBuilder, AppHandle, Manager, Runtime
};

pub fn create_tray<R: Runtime>(app: &AppHandle<R>) -> tauri::Result<()> {
    let toggle_visibility = MenuItem::with_id(app, "toggle", "显示/隐藏窗口", true, None::<&str>)?;
    let quit = MenuItem::with_id(app, "quit", "退出", true, None::<&str>)?;
    
    let menu = Menu::with_items(app, &[&toggle_visibility, &quit])?;
    
    let _tray = TrayIconBuilder::new()
        .icon(app.default_window_icon().unwrap().clone())
        .tooltip("tauri-vite-vue3")
        .menu(&menu)
        .on_menu_event(move |app, event| match event.id.as_ref() {
            "toggle" => {
                if let Some(window) = app.get_webview_window("main") {
                    if window.is_visible().unwrap() {
                        let _ = window.hide();
                    } else {
                        let _ = window.show();
                        let _ = window.set_focus();
                    }
                }
            }
            "quit" => {
                app.exit(0);
            }
            _ => {}
        })
        .build(app)?;

    Ok(())
}

右键托盘,有两个菜单:显示/隐藏窗口,退出。

tooltip是鼠标移到托盘上显示的内容。

2、引入托盘

在main.rs里引入tray.rs,并且创建托盘:

rust 复制代码
// Prevents additional console window on Windows in release, DO NOT REMOVE!!
#![cfg_attr(not(debug_assertions), windows_subsystem = "windows")]

mod tray;

#[cfg_attr(mobile, tauri::mobile_entry_point)]
pub fn run() {
    tauri::Builder::default()
        .setup(|app| {
            // 创建系统托盘
            tray::create_tray(app.handle())?;
            Ok(())
        })
        .run(tauri::generate_context!())
        .expect("error while running tauri application");
}

fn main() {
    run();
}

3、监听窗口关闭事件

在App.vue里监听窗口关闭行为,并且emit给tauri来处理。

javascript 复制代码
<script setup>
import { getCurrentWindow } from '@tauri-apps/api/window';
import { emit } from '@tauri-apps/api/event';
import { onMounted } from "vue";


const appWindow = getCurrentWindow();


// 在组件挂载时添加事件监听
onMounted(() => {
  // 监听窗口关闭请求
  appWindow.onCloseRequested(async (event) => {
    // 阻止默认的关闭行为
    event.preventDefault();
    // 发送事件到后端处理
    await emit('close_requested');
  });

});

4、处理窗口关闭事件

由于后续我还要添加其他窗口处理,所以另外创建一个window_manager.rs,代码统一写在这里:

这里写了两个方法:窗口最大化;处理close_requested事件,隐藏窗口。

rust 复制代码
// src/window_manager.rs
use tauri::{AppHandle, Listener, Manager, Runtime};


/// 设置窗口关闭事件监听器
pub fn setup_close_listener<R: Runtime>(app: &AppHandle<R>) {
    let app_handle = app.clone();
    app.listen_any("close_requested", move |_event| {
        if let Some(window) = app_handle.get_webview_window("main") {
            let _ = window.hide();
        }
    });
}



/// 设置所有窗口相关功能
pub fn setup_window_features<R: Runtime>(app: &AppHandle<R>) {
    setup_close_listener(app);
}

5、引入窗口处理

跟步骤2创建托盘类似,也要在main.rs里引入window_manager。

一个简单的托盘案例就做好了。

相关推荐
于慨2 天前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz2 天前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶2 天前
前端交互规范(Web 端)
前端
像我这样帅的人丶你还2 天前
别再让JS耽误你进步了。
css·vue.js
@yanyu6662 天前
07-引入element布局及spring boot完善后端
javascript·vue.js·spring boot
CHU7290352 天前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing2 天前
Page-agent MCP结构
前端·人工智能
王霸天2 天前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航2 天前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界2 天前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript