Electron实现系统托盘图标右键出现菜单

实现效果图

在这里插入图片描述

实现代码

const { app, BrowserWindow, Tray, Menu, } = require('electron');
const path = require('path');
//入口文件
let indexHtml = 'http://localhost:' + 8080 + '/xiongxin/';
//熊信图标路径
const iconPath = path.join(__dirname,`../src/assets/logo/icon.png`);

//所有窗体
let windows = {
	mainWindow: null, //主窗口
}
//系统托盘实例
let appTray = null;

/**
 * 创建系统托盘
 */
function createAppTray(){
	//系统托盘
	appTray = new Tray(iconPath);
	//定义系统托盘菜单
	const trayContextMenu = Menu.buildFromTemplate([
		{
			label: "系统设置",
			click:() => {
			}
		},
		{
			label: "关于熊信",
			click:() => {
			}
		},
		{
			label: "退出熊信",
			click:() => {
				app.quit();
			}
		},
	]);
	//系统托盘右键点击事件
	appTray.on('right-click',() => {
		appTray.popUpContextMenu(trayContextMenu);//显示系统托盘菜单
	});
	//系统托盘的提示文本
	appTray.setToolTip('熊信');
	//点击系统托盘打开窗口
	appTray.on('click',() => {
		windows.mainWindow.show();
	});
	
}

//创建主窗口
const createMainWindow = () => {
    //创建并控制浏览器窗口。
    windows.mainWindow = new BrowserWindow({
        width: 1200,
        height: 900,
        minWidth: 900,
        minHeight: 600,
        frame: false, // 无边框
        icon: iconPath,// 窗口图标
        webPreferences: {//网页功能设置。
            preload: path.join(__dirname, 'preload.js'),//在页面运行其他脚本之前预先加载指定的脚本 无论页面是否集成Node, 此脚本都可以访问所有Node API 脚本路径为文件的绝对路径。
            webSecurity: false,//禁用同源策略
            nodeIntegration: true,
            nodeIntegrationInWorker: true
        }
    });
    //加载路径
    windows.mainWindow.loadURL(indexHtml);
	
	//创建系统托盘
	createAppTray()
	
	//设置系统托盘闪烁
	flashFrame(true)
};

//当Electron 初始化完成时触发
app.whenReady().then(() => {
    createMainWindow();//创建主窗口
    app.on('activate', () => { // macOS 应用通常即使在没有打开任何窗口的情况下也继续运行,并且在没有窗口可用的情况下激活应用时会打开新的窗口。
        if (BrowserWindow.getAllWindows().length === 0) createMainWindow();
    });
});

//关闭所有窗口时退出应用 ,监听 app 模块的 'window-all-closed' 事件。如果用户不是在 macOS(darwin) 上运行程序,则调用 app.quit()。
app.on('window-all-closed', () => {
    if (process.platform !== 'darwin') app.quit();
});

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值