托盘
概述
本指南将引导您完成在系统通知区域创建一个带有自己的上下文菜单的托盘图标的过程。
在 macOS 和 Ubuntu 上,托盘将位于屏幕右上角,与电池和 wifi 图标相邻。在 Windows 上,托盘通常位于右下角。
示例
main.js
首先,我们必须从 electron
导入 app
、Tray
、Menu
、nativeImage
。
const { app, Tray, Menu, nativeImage } = require('electron')
接下来,我们将创建我们的托盘。为此,我们将使用一个NativeImage
图标,可以通过这些方法中的任何一种创建。请注意,我们将托盘创建代码包裹在app.whenReady
中,因为我们需要等待我们的 electron 应用完成初始化。
main.js
let tray
app.whenReady().then(() => {
const icon = nativeImage.createFromPath('path/to/asset.png')
tray = new Tray(icon)
// note: your contextMenu, Tooltip and Title code will go here!
})
太棒了!现在我们可以开始将上下文菜单附加到我们的托盘了,就像这样
const contextMenu = Menu.buildFromTemplate([
{ label: 'Item1', type: 'radio' },
{ label: 'Item2', type: 'radio' },
{ label: 'Item3', type: 'radio', checked: true },
{ label: 'Item4', type: 'radio' }
])
tray.setContextMenu(contextMenu)
上面的代码将在上下文菜单中创建 4 个单独的单选类型项目。要了解有关构造本机菜单的更多信息,请点击此处。
最后,让我们给我们的托盘一个工具提示和一个标题。
tray.setToolTip('This is my application')
tray.setTitle('This is my title')
结论
启动您的 electron 应用后,您应该看到托盘位于屏幕的顶部或右下角,具体取决于您的操作系统。
- main.js
- index.html
const { app, Tray, Menu, nativeImage } = require('electron/main')
let tray
app.whenReady().then(() => {
const icon = nativeImage.createFromDataURL('')
tray = new Tray(icon)
const contextMenu = Menu.buildFromTemplate([
{ label: 'Item1', type: 'radio' },
{ label: 'Item2', type: 'radio' },
{ label: 'Item3', type: 'radio', checked: true },
{ label: 'Item4', type: 'radio' }
])
tray.setToolTip('This is my application.')
tray.setContextMenu(contextMenu)
})
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>Tray</title>
</head>
<body>
<div>
<h1>Tray</h1>
<h3>
The <code>tray</code> module allows you to create an icon in the
operating system's notification area.
</h3>
<p>This icon can also have a context menu attached.</p>
<p>
Open the
<a href="https://electron.js.cn/docs/latest/api/tray">
full API documentation
</a>
in your browser.
</p>
</div>
<div>
<div>
<h2>ProTip</h2>
<strong>Tray support in Linux.</strong>
<p>
On Linux distributions that only have app indicator support, users
will need to install <code>libappindicator1</code> to make the
tray icon work. See the
<a href="https://electron.js.cn/docs/latest/api/tray">
full API documentation
</a>
for more details about using Tray on Linux.
</p>
</div>
</div>
</div>
</div>
<script>
// You can also require other files to run in this process
require("./renderer.js");
</script>
</body>
</html>