Electron中使用tray模块实现系统拖盘

本文详细介绍了Electron中Tray模块的功能与使用方法,包括创建拖盘图标、设置鼠标悬停提示、配置拖盘右键菜单、实现点击关闭保存到拖盘等功能,并提供了完整的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Electron中的tray模块主要用来实现桌面软件特有的拖盘功能,包括创建拖盘图标、拖盘悬停提示、拖盘右键菜单、拖盘消息提示等等。

1. 创建拖盘

var { Menu, Tray, BrowserWindow, app } = require('electron');
var path = require('path');

// 创建拖盘
var iconTray = new Tray(path.join(__dirname,'../static/love.png'));

2. 鼠标悬停拖盘提示

// 鼠标悬停托盘提示
iconTray.setToolTip('Electron应用');

3. 拖盘右键菜单

// 配置右键菜单
var trayMenu = Menu.buildFromTemplate([
    {
        label: '设置',
        click: function () {
            console.log('setting')
        }
    },
    {
        label: '升级',
        click: function () {
            console.log('update')
        }
    },
    {
        label: '退出',
        click: function () {
            if (process.platform !== 'darwin') {
                app.quit();
            }
        }
    }
]);
// 绑定右键菜单到托盘
iconTray.setContextMenu(trayMenu);

4. 点击关闭保存到拖盘

setTimeout(function(){
    var win = BrowserWindow.getFocusedWindow();
    // 点击关闭按钮让应用保存在托盘
    win.on('close', (e) => {
        if (!win.isFocused()) {
            win = null;
        } else {
            // 阻止窗口的关闭事件
            e.preventDefault();  
            win.hide();
        }
    });
})

5. 双击拖盘打开应用

// 任务栏图标双击托盘打开应用
iconTray.on('double-click', function () {
    win.show();
});

6. 新消息提示

// 消息提示
var count = 0;
var timer = setInterval(function () {
    count++;
    if (count % 2 == 0) {
        iconTray.setImage(path.join(__dirname,'../static/love.png'));
    } else {
        iconTray.setImage(path.join(__dirname,'../static/empty.png'));
    }
}, 500)

7. 图标注意事项

8. 代码完整示例

主进程文件main.js代码:

// main.js
const { app, BrowserWindow } = require("electron");
const path = require("path");


const createWindow = () => {

    // 创建窗口
    const mainWindow = new BrowserWindow({
        width: 800,
        height: 600,
        webPreferences: {
            // 开启node
            nodeIntegration: true,
            // 取消上下文隔离
            contextIsolation: false,
            // 开启remote
            enableRemoteModule:true,
        }
    });
    // 加载本地文件
    mainWindow.loadFile(path.join(__dirname, "index.html"));
    // 加载远程地址
    // mainWindow.loadURL('https://github.com');

    // 开启调试模式
    mainWindow.webContents.openDevTools();


	// 自定义底部拖盘
	require('./main/ipcMain');

}

// 监听应用的启动事件
app.on("ready", createWindow);

// 兼容MacOS系统的窗口关闭功能
app.on("window-all-closed", () => {
    // 非MacOS直接退出
    if (process.platform != "darwin") {
        app.quit();
    }
});

// 点击MacOS底部菜单时重新启动窗口
app.on("activate", () => {
    if (BrowserWindow.getAllWindows.length == 0) {
        createWindow();
    }
})

主进程文件main.js中引入的ipcMain.js文件代码:

var { Menu, Tray, BrowserWindow, app } = require('electron');
var path = require('path');

// 创建拖盘
var iconTray = new Tray(path.join(__dirname,'../static/love.png'));

// 鼠标悬停托盘提示
iconTray.setToolTip('Electron应用');


// 配置右键菜单
var trayMenu = Menu.buildFromTemplate([
    {
        label: '设置',
        click: function () {
            console.log('setting')
        }
    },
    {
        label: '升级',
        click: function () {
            console.log('update')
        }
    },
    {
        label: '退出',
        click: function () {
            if (process.platform !== 'darwin') {
                app.quit();
            }
        }
    }
]);
// 绑定右键菜单到托盘
iconTray.setContextMenu(trayMenu);



setTimeout(function(){
    var win = BrowserWindow.getFocusedWindow();
    // 点击关闭按钮让应用保存在托盘
    win.on('close', (e) => {
        if (!win.isFocused()) {
            win = null;
        } else {
            // 阻止窗口的关闭事件
            e.preventDefault();  
            win.hide();
        }
    });
})


// 任务栏图标双击托盘打开应用
iconTray.on('double-click', function () {
    win.show();
});

// 消息提示
var count = 0;
var timer = setInterval(function () {
    count++;
    if (count % 2 == 0) {
        iconTray.setImage(path.join(__dirname,'../static/love.png'));
    } else {
        iconTray.setImage(path.join(__dirname,'../static/empty.png'));
    }
}, 500);

渲染进程文件index.html代码:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Electron开发</title>
</head>
<body>
	<p>Electron中Tray模块实现系统托盘功能</p>
</body>

</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

艾光远

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值