从零开始学Electron笔记(七)

时间:2023-03-10 02:42:13
从零开始学Electron笔记(七)

在之前的文章我们介绍了一下Electron中的对话框 Dialog和消息通知 Notification,接下来我们继续说一下Electron中的系统快捷键及应用打包。

全局快捷键模块就是 globalShortcut,意思就是我们打开软件以后,按键盘上的快捷键,就可以实现用快捷键实现特定的功能,相当于用键盘快捷键触发某些事件。

globalShortcut 官方地址:https://www.electronjs.org/docs/api/global-shortcut

globalShortcut 模块可以在操作系统中注册/注销全局快捷键, 以便可以为操作定制各种快捷键。

注意: 快捷方式是全局的; 即使应用程序没有键盘焦点, 它也仍然在持续监听键盘事件。 在应用程序模块发出 ready  事件之前, 不应使用此模块。

我们的目录结构如下:

从零开始学Electron笔记(七)

globalShortcut 模块存在于主进程中,我们先来通过代码来看一下 globalShortcut 的注册及调用,代码主要在 index.js 中,如下:

 const {app, BrowserWindow, globalShortcut, dialog} = require('electron')

 function createWindow() {
// 创建浏览器窗口
const win = new BrowserWindow({
width: 800,
height: 600,
webPreferences: {
nodeIntegration: true
}
}) //引入 menu.js
require('./menu');
// 并且为你的应用加载index.html
win.loadFile('index.html'); // 打开开发者工具
win.webContents.openDevTools()
} // Electron会在初始化完成并且准备好创建浏览器窗口时调用这个方法
// 部分 API 在 ready 事件触发后才能使用。
app.whenReady().then(createWindow); app.on('ready', () => {
// 注册一个 'CommandOrControl+X' 的全局快捷键
const ret = globalShortcut.register('Command+X', () => {
dialog.showMessageBox({
message: 'Command+X 快捷键调用成功!'
}).then(() => {
});
}); if (!ret) {
dialog.showMessageBox({
message: 'Command+X 快捷键调用失败!'
}).then(() => {});
} // 检查快捷键是否注册成功
dialog.showMessageBox({
message: 'Command+X 快捷键注册 ' + globalShortcut.isRegistered('Command+X')
}).then(() => {});
}); app.on('will-quit', () => {
// 注销快捷键
globalShortcut.unregister('Command+X'); // 注销所有快捷键
globalShortcut.unregisterAll()
});

在上面的代码中可以看出,我们注册了一个 Command+X 的快捷键,并且弹出一个 dialog 的对话框。

我们在注册系统快捷键的时候要先使用 globalShortcut.isRegistered() 方法,来检测快捷键是否注册成功,因为你可能同时打开很多软件,它们已经占用了一些快捷键的组合,所以并不是你100%可以注册成功的。

在关闭程序的时候要注销所有的快捷键,因为我们注册的是全局的快捷键,所以当我们关闭软件或者窗口时,记得一定要注销我们的快捷键。防止关闭后打开其他软件和他们的快捷键冲突。

当我们使用了Electron开发完应用后,一定想着如何打包成exe文件,打包的方式有很多,甚至根据你使用不同的前端框架,打包方式也会有所不同。这里我们用原汁原味的打包方式,用electron-package 打包。

首先我们先通过 npm 来下载 electron-package 包,

npm install electron-packager --save

然后在控制台输入

electron-packager <location of project> <name of project> <platform> <architecture> <electron version> <optional options>

其中我们需要输入6个参数,这6个参数意思分别是:

  • location of project : 项目所在路径
  • name of project : 打包的项目名称
  • platform : 确定了你要构建哪个平台的应用(Windows、Mac还是Liux)
  • architecture: 决定了使用x86还是x64还是两个架构都需要
  • electron version: electron 的版本
  • optional options: 可选选项

为了打包方便我们可以在 package.json 的 scripts 中添加如下代码,相当于快捷方式的作用:

"packager": "electron-packager ./ myElectron --all --out ./dist  --overwrite --icon=./img/icon/icon.ico"

在项目中新建 dist 文件夹。

使用 npm run packager 就可以进行打包了,打包的时间会非常长,而且如果你安装了一些安全软件,还要时刻看着安全软件的禁止操作,如果不小心被禁止掉了,可能会造成打包的失败。

最后我们来看一下运行打包的结果:

从零开始学Electron笔记(七)

双击 myElectron 就可以运行我们打包的程序来。