跳至主要内容

任务栏自定义

概览

Electron 拥有在 Windows 任务栏中配置应用程序图标的 API。 此 API 支持仅限 Windows 的功能,例如 创建 JumpList自定义缩略图和工具栏图标覆盖和所谓的 “闪烁帧”效果,以及跨平台功能,例如最近使用的文档应用程序进度

JumpList

Windows 允许应用程序定义一个自定义上下文菜单,该菜单在用户右键单击任务栏中的应用程序图标时显示。 该上下文菜单称为JumpList。 您可以在 JumpList 的Tasks类别中指定自定义操作,如下引自 MSDN

应用程序根据程序的功能以及用户期望用它们做的关键事情来定义任务。 任务应该是无上下文的,因为应用程序不需要运行才能使它们工作。 它们也应该是普通用户在应用程序中执行的统计上最常见的操作,例如撰写电子邮件或打开邮件程序中的日历,在文字处理器中创建新文档,以某种模式启动应用程序,或启动它的子命令之一。 应用程序不应使用标准用户不需要的高级功能或一次性操作(例如注册)来弄乱菜单。 不要使用任务进行促销项目,例如升级或特别优惠。

强烈建议任务列表是静态的。 无论应用程序的状态如何,它都应该保持不变。 虽然可以动态地更改列表,但您应该考虑到这可能会使用户感到困惑,他们不希望目标列表的这一部分发生更改。

Taskbar JumpList

注意:上面的屏幕截图是 Microsoft Edge 的一般任务示例

与 macOS 中作为真实菜单的 dock 菜单不同,Windows 中的用户任务就像应用程序快捷方式一样工作。 例如,当用户单击一个任务时,程序将使用指定的参数执行。

要为您的应用程序设置用户任务,您可以使用app.setUserTasks API。

示例

设置用户任务

教程启动代码中的一个工作应用程序开始,使用以下几行更新main.js文件

const { app } = require('electron')

app.setUserTasks([
{
program: process.execPath,
arguments: '--new-window',
iconPath: process.execPath,
iconIndex: 0,
title: 'New Window',
description: 'Create a new window'
}
])
清除任务列表

要清除您的任务列表,您需要在main.js文件中使用一个空数组来调用app.setUserTasks

const { app } = require('electron')

app.setUserTasks([])

注意:即使在关闭应用程序后,用户任务仍然会显示,因此为任务指定的图标和程序路径应存在直到您的应用程序被卸载。

缩略图工具栏

在 Windows 上,您可以将带有指定按钮的缩略图工具栏添加到应用程序窗口的任务栏布局中。 它为用户提供了一种访问特定窗口命令的方式,而无需恢复或激活该窗口。

如下引自 MSDN

该工具栏是熟悉的标准工具栏通用控件。 它最多有七个按钮。 每个按钮的 ID、图像、工具提示和状态都在一个结构中定义,然后传递给任务栏。 应用程序可以根据其当前状态显示、启用、禁用或隐藏缩略图工具栏中的按钮。

例如,Windows Media Player 可能会提供标准的媒体传输控件,例如播放、暂停、静音和停止。

Thumbnail toolbar

注意:上面的屏幕截图是 Windows Media Player 的缩略图工具栏示例

要在您的应用程序中设置缩略图工具栏,您需要使用BrowserWindow.setThumbarButtons

示例

设置缩略图工具栏

教程启动代码中的一个工作应用程序开始,使用以下几行更新main.js文件

const { BrowserWindow, nativeImage } = require('electron')
const path = require('node:path')

const win = new BrowserWindow()

win.setThumbarButtons([
{
tooltip: 'button1',
icon: nativeImage.createFromPath(path.join(__dirname, 'button1.png')),
click () { console.log('button1 clicked') }
}, {
tooltip: 'button2',
icon: nativeImage.createFromPath(path.join(__dirname, 'button2.png')),
flags: ['enabled', 'dismissonclick'],
click () { console.log('button2 clicked.') }
}
])
清除缩略图工具栏

要清除缩略图工具栏按钮,您需要在main.js文件中使用一个空数组来调用BrowserWindow.setThumbarButtons

const { BrowserWindow } = require('electron')

const win = new BrowserWindow()
win.setThumbarButtons([])

任务栏中的图标覆盖

在 Windows 上,任务栏按钮可以使用一个小的覆盖来显示应用程序状态。

如下引自 MSDN

图标覆盖用作状态的上下文通知,旨在消除对单独的通知区域状态图标的需求,以将该信息传达给用户。 例如,Microsoft Outlook 中的新邮件状态当前显示在通知区域中,现在可以通过任务栏按钮上的覆盖来指示。 同样,您必须在开发周期中决定哪种方法最适合您的应用程序。 覆盖图标旨在提供重要的、持久的状态或通知,例如网络状态、消息传递状态或新邮件。 不应向用户显示不断变化的覆盖或动画。

Overlay on taskbar button

注意:上面的屏幕截图是任务栏按钮上的覆盖示例

要为窗口设置覆盖图标,您需要使用 BrowserWindow.setOverlayIcon API。

示例

教程启动代码中的一个工作应用程序开始,使用以下几行更新main.js文件

const { BrowserWindow, nativeImage } = require('electron')

const win = new BrowserWindow()

win.setOverlayIcon(nativeImage.createFromPath('path/to/overlay.png'), 'Description for overlay')

闪烁帧

在 Windows 上,您可以突出显示任务栏按钮以引起用户的注意。 这类似于在 macOS 中跳动 dock 图标。

如下引自 MSDN

通常,窗口会闪烁以通知用户该窗口需要注意,但当前没有键盘焦点。

要闪烁 BrowserWindow 任务栏按钮,您需要使用 BrowserWindow.flashFrame API。

示例

教程启动代码中的一个工作应用程序开始,使用以下几行更新main.js文件

const { BrowserWindow } = require('electron')

const win = new BrowserWindow()

win.once('focus', () => win.flashFrame(false))
win.flashFrame(true)

注意:不要忘记调用 win.flashFrame(false) 以关闭闪烁。 在上面的示例中,当窗口进入焦点时会调用它,但您可以使用超时或其他事件来禁用它。