加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

electron实现最小化到托盘

发布时间:2020-12-16 08:32:28 所属栏目:百科 来源:网络整理
导读:当我们在无边框下使用关闭按钮时,我们可能并不是想关闭应用,而只想他最小化在托盘中,随时等待唤醒,还好,electron依旧给我们提供了这个功能。 一、主进程 主进程中监听窗口关闭事件,在这,我们需要使用到electron的menu模块来创建菜单以及tray托盘模块

当我们在无边框下使用关闭按钮时,我们可能并不是想关闭应用,而只想他最小化在托盘中,随时等待唤醒,还好,electron依旧给我们提供了这个功能。

一、主进程

主进程中监听窗口关闭事件,在这,我们需要使用到electron的menu模块来创建菜单以及tray托盘模块。

const electron = require('electron');
const Menu = electron.Menu;
const Tray = electron.Tray;

当托盘最小化后,右击时是有个菜单显示的,此处仅创建一个含有退出的菜单,

let trayMenuTemplate = [{//系统托盘图标目录
    label:'退出',
    click: function () {
        app.quit();
    }
}];

下面我们创建托盘实例,并且给实例增加上一些属性和菜单,

leticonPath=path.join(__dirname, 'app.png');
appTray = new Tray(iconPath);
const contextMenu = Menu.buildFromTemplate(trayMenuTemplate);
// 设置托盘悬浮提示
appTray.setToolTip('never forget');
// 设置托盘菜单
appTray.setContextMenu(contextMenu);

当我们左键托盘时,是需要显示应用的,所以再增加个点击事件就完工啦。

appTray.on('click', function(){
    // 显示主程序
    mainWindow.show();
    // 关闭托盘显示
    appTray.destroy();
});

附上托盘的整个代码。

const electron = require('electron');
let appTray = null;   // 引用放外部,防止被当垃圾回收

// 隐藏主窗口,并创建托盘,绑定关闭事件
function setTray () {
    // 用一个 Tray 来表示一个图标,这个图标处于正在运行的系统的通知区
    //  ,通常被添加到一个 context menu 上.
    const Menu = electron.Menu;
    const Tray = electron.Tray;
    // 系统托盘右键菜单
    let trayMenuTemplate = [{     // 系统托盘图标目录
        label: '退出',
        click: function () {
            app.quit();
        }
    }];
    // 当前目录下的app.ico图标
    let iconPath = path.join(__dirname, 'app.png');
    appTray = newTray(iconPath);
    // 图标的上下文菜单
    const contextMenu = Menu.buildFromTemplate(trayMenuTemplate);
    // 隐藏主窗口
    mainWindow.hide();
    // 设置托盘悬浮提示
    appTray.setToolTip('never forget');
    // 设置托盘菜单
    appTray.setContextMenu(contextMenu);
    // 单击托盘小图标显示应用
    appTray.on('click', function(){
        // 显示主程序
        mainWindow.show();
        // 关闭托盘显示
        appTray.destroy();
    });
};


(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读