跳到主要内容

systemPreferences

获取系统偏好设置。

进程:主进程实用进程

const { systemPreferences } = require('electron')
console.log(systemPreferences.getEffectiveAppearance())

事件

`systemPreferences` 对象发出以下事件

事件:'accent-color-changed' Windows

返回

  • event 事件
  • newColor string - 用户指定作为系统强调色的新的 RGBA 颜色。

事件:'color-changed' Windows

返回

  • event 事件

方法

systemPreferences.isSwipeTrackingFromScrollEventsEnabled() macOS

返回 boolean - “在页面间轻扫”设置是否开启。

systemPreferences.postNotification(event, userInfo[, deliverImmediately]) macOS

  • event string
  • userInfo Record<string, any>
  • deliverImmediately boolean (可选) - 如果为 true,即使订阅的应用程序处于非活动状态,也会立即发布通知。

以 macOS 原生通知的形式发布 eventuserInfo 是一个对象,包含与通知一起发送的用户信息字典。

systemPreferences.postLocalNotification(event, userInfo) macOS

  • event string
  • userInfo Record<string, any>

以 macOS 原生通知的形式发布 eventuserInfo 是一个对象,包含与通知一起发送的用户信息字典。

systemPreferences.postWorkspaceNotification(event, userInfo) macOS

  • event string
  • userInfo Record<string, any>

以 macOS 原生通知的形式发布 eventuserInfo 是一个对象,包含与通知一起发送的用户信息字典。

systemPreferences.subscribeNotification(event, callback) macOS

  • event string | null
  • callback Function
    • event string
    • userInfo Record<string, unknown>
    • object string

返回 number - 此订阅的 ID

订阅 macOS 原生通知,当相应的 event 发生时,将调用 callback,参数为 callback(event, userInfo)userInfo 是一个对象,包含与通知一起发送的用户信息字典。object 是通知的发送者,目前仅支持 NSString 值。

返回订阅者的 id,可用于取消订阅 event

在底层,此 API 订阅了 NSDistributedNotificationCenterevent 的示例值如下:

  • AppleInterfaceThemeChangedNotification
  • AppleAquaColorVariantChanged
  • AppleColorPreferencesChangedNotification
  • AppleShowScrollBarsSettingChanged

如果 event 为 null,则 NSDistributedNotificationCenter 不将其用作传递给观察者的标准。有关更多信息,请参阅 文档

systemPreferences.subscribeLocalNotification(event, callback) macOS

  • event string | null
  • callback Function
    • event string
    • userInfo Record<string, unknown>
    • object string

返回 number - 此订阅的 ID

subscribeNotification 相同,但使用 NSNotificationCenter 处理本地默认值。这对于 NSUserDefaultsDidChangeNotification 等事件是必需的。

如果 event 为 null,则 NSNotificationCenter 不将其用作传递给观察者的标准。有关更多信息,请参阅 文档

systemPreferences.subscribeWorkspaceNotification(event, callback) macOS

  • event string | null
  • callback Function
    • event string
    • userInfo Record<string, unknown>
    • object string

返回 number - 此订阅的 ID

subscribeNotification 相同,但使用 NSWorkspace.sharedWorkspace.notificationCenter。这对于 NSWorkspaceDidActivateApplicationNotification 等事件是必需的。

如果 event 为 null,则 NSWorkspaceNotificationCenter 不将其用作传递给观察者的标准。有关更多信息,请参阅 文档

systemPreferences.unsubscribeNotification(id) macOS

  • id Integer

移除 ID 为 id 的订阅者。

systemPreferences.unsubscribeLocalNotification(id) macOS

  • id Integer

unsubscribeNotification 相同,但从 NSNotificationCenter 中移除订阅者。

systemPreferences.unsubscribeWorkspaceNotification(id) macOS

  • id Integer

unsubscribeNotification 相同,但从 NSWorkspace.sharedWorkspace.notificationCenter 中移除订阅者。

systemPreferences.registerDefaults(defaults) macOS

  • defaults Record<string, string | boolean | number> - 用户默认设置的 (key: value) 字典

将指定的默认值添加到应用程序的 NSUserDefaults 中。

systemPreferences.getUserDefault<Type extends keyof UserDefaultTypes>(key, type) macOS

  • key string
  • type Type - 可以是 stringbooleanintegerfloatdoubleurlarraydictionary

返回 UserDefaultTypes[Type] - NSUserDefaultskey 的值。

一些常用的 keytype 为:

  • AppleInterfaceStyle: string
  • AppleAquaColorVariant: integer
  • AppleHighlightColor: string
  • AppleShowScrollBars: string
  • NSNavRecentPlaces: array
  • NSPreferredWebServices: dictionary
  • NSUserDictionaryReplacementItems: array

systemPreferences.setUserDefault<Type extends keyof UserDefaultTypes>(key, type, value) macOS

  • key string
  • type Type - 可以是 stringbooleanintegerfloatdoubleurlarraydictionary
  • value UserDefaultTypes[Type]

NSUserDefaults 中设置 key 的值。

注意,type 应与 value 的实际类型匹配。如果不匹配,则会抛出异常。

一些常用的 keytype 为:

  • ApplePressAndHoldEnabled: boolean

systemPreferences.removeUserDefault(key) macOS

  • key string

移除 NSUserDefaults 中的 key。这可用于恢复之前通过 setUserDefault 设置的 key 的默认或全局值。

systemPreferences.getAccentColor() Windows macOS

返回 string - 用户当前的系统范围强调色偏好设置,格式为 RGBA 十六进制。

const color = systemPreferences.getAccentColor() // `"aabbccdd"`
const red = color.substr(0, 2) // "aa"
const green = color.substr(2, 2) // "bb"
const blue = color.substr(4, 2) // "cc"
const alpha = color.substr(6, 2) // "dd"

此 API 仅在 macOS 10.14 Mojave 或更高版本上可用。

systemPreferences.getColor(color) Windows macOS

  • color string - 以下值之一:
    • Windows
      • 3d-dark-shadow - 三维显示元素的深阴影。
      • 3d-face - 三维显示元素的表面颜色以及对话框背景。
      • 3d-highlight - 三维显示元素的高光颜色。
      • 3d-light - 三维显示元素的浅色。
      • 3d-shadow - 三维显示元素的阴影颜色。
      • active-border - 活动窗口边框。
      • active-caption - 活动窗口标题栏。如果启用了渐变效果,则指定活动窗口标题栏颜色渐变的左侧颜色。
      • active-caption-gradient - 活动窗口标题栏颜色渐变的右侧颜色。
      • app-workspace - 多文档界面 (MDI) 应用程序的背景颜色。
      • button-text - 按钮上的文本。
      • caption-text - 标题、大小框和滚动条箭头框中的文本。
      • desktop - 桌面背景颜色。
      • disabled-text - 灰色 (禁用) 文本。
      • highlight - 控件中选中的项目。
      • highlight-text - 控件中选中的项目的文本。
      • hotlight - 超链接或热跟踪项目的颜色。
      • inactive-border - 非活动窗口边框。
      • inactive-caption - 非活动窗口标题。如果启用了渐变效果,则指定非活动窗口标题栏颜色渐变的左侧颜色。
      • inactive-caption-gradient - 非活动窗口标题栏颜色渐变的右侧颜色。
      • inactive-caption-text - 非活动标题中的文本颜色。
      • info-background - 工具提示控制的背景颜色。
      • info-text - 工具提示控制的文本颜色。
      • menu - 菜单背景。
      • menu-highlight - 当菜单显示为平面菜单时用于高亮显示菜单项的颜色。
      • menubar - 当菜单显示为平面菜单时菜单栏的背景颜色。
      • menu-text - 菜单中的文本。
      • scrollbar - 滚动条灰色区域。
      • window - 窗口背景。
      • window-frame - 窗口框架。
      • window-text - 窗口中的文本。
    • macOS
      • control-background - 大型界面元素(如浏览器或表格)的背景。
      • control - 控件的表面。
      • control-text - 未禁用的控件的文本。
      • disabled-control-text - 已禁用控件的文本。
      • find-highlight - 查找指示器的颜色。
      • grid - 表格等界面元素的网格线。
      • header-text - 表格中标题单元格的文本。
      • highlight - 屏幕上的虚拟光源。
      • keyboard-focus-indicator - 使用键盘进行界面导航时,当前聚焦控件周围出现的环形。
      • label - 包含主要内容的标签的文本。
      • link - 指向其他内容的链接。
      • placeholder-text - 控件或文本视图中的占位符字符串。
      • quaternary-label - 重要性低于三级标签的标签的文本,例如水印文本。
      • scrubber-textured-background - 触控栏中滑动条的背景。
      • secondary-label - 重要性低于普通标签的标签的文本,例如用于表示副标题或附加信息的标签。
      • selected-content-background - 关键窗口或视图中选中内容的背景。
      • selected-control - 选中控件的表面。
      • selected-control-text - 选中控件的文本。
      • selected-menu-item-text - 选中菜单的文本。
      • selected-text-background - 选中文本的背景。
      • selected-text - 选中文本。
      • separator - 内容不同部分之间的分隔符。
      • shadow - 屏幕上凸起物体投射的虚拟阴影。
      • tertiary-label - 重要性低于二级标签的标签的文本,例如用于表示禁用文本的标签。
      • text-background - 文本背景。
      • text - 文档中的文本。
      • under-page-background - 文档内容背后的背景。
      • unemphasized-selected-content-background - 非关键窗口或视图中选中内容的背景。
      • unemphasized-selected-text-background - 非关键窗口或视图中选中文本的背景。
      • unemphasized-selected-text - 非关键窗口或视图中选中的文本。
      • window-background - 窗口的背景。
      • window-frame-text - 窗口标题栏区域的文本。

返回 string - 系统颜色设置,格式为 RGBA 十六进制 (#RRGGBBAA)。有关更多详细信息,请参阅 Windows 文档macOS 文档

以下颜色仅在 macOS 10.14 上可用:find-highlightselected-content-backgroundseparatorunemphasized-selected-content-backgroundunemphasized-selected-text-backgroundunemphasized-selected-text

systemPreferences.getSystemColor(color) macOS

  • color string - 以下值之一:
    • blue
    • brown
    • gray
    • green
    • orange
    • pink
    • purple
    • red
    • yellow

返回 string - 标准系统颜色,格式为 #RRGGBBAA

返回几种标准系统颜色之一,这些颜色会自动适应鲜艳度和可访问性设置(如“增加对比度”和“降低透明度”)的变化。有关更多详细信息,请参阅 Apple 文档

systemPreferences.getEffectiveAppearance() macOS

返回 string - 可以是 darklightunknown

获取当前应用于应用程序的 macOS 外观设置,映射到 NSApplication.effectiveAppearance

systemPreferences.canPromptTouchID() macOS

返回 boolean - 此设备是否具有使用触控 ID 的能力。

systemPreferences.promptTouchID(reason) macOS

  • reason string - 请求 Touch ID 认证的原因

返回 Promise<void> - 如果用户已成功通过 Touch ID 认证,则解析。

const { systemPreferences } = require('electron')

systemPreferences.promptTouchID('To get consent for a Security-Gated Thing').then(success => {
console.log('You have successfully authenticated with Touch ID!')
}).catch(err => {
console.log(err)
})

此 API 本身不会保护您的用户数据;它只是一个机制,让您能够实现这一点。原生应用程序需要在其密钥链条目上设置 访问控制常量 (Access Control Constants),例如 kSecAccessControlUserPresence,以便读取它时会自动提示进行 Touch ID 生物识别同意。这可以使用 node-keytar 完成,例如使用 node-keytar 存储加密密钥,并仅在 promptTouchID() 解析时才获取它。

systemPreferences.isTrustedAccessibilityClient(prompt) macOS

  • prompt boolean - 如果当前进程不受信任,是否通过提示告知用户。

返回 boolean - 如果当前进程是受信任的可访问性客户端,则为 true,否则为 false

systemPreferences.getMediaAccessStatus(mediaType) Windows macOS

  • mediaType string - 可以是 microphonecamerascreen

返回 string - 可以是 not-determinedgranteddeniedrestrictedunknown

在 macOS 10.13 High Sierra 上不需要此用户同意,因此此方法将始终返回 granted。macOS 10.14 Mojave 或更高版本需要 microphonecamera 访问权限的同意。macOS 10.15 Catalina 或更高版本需要 screen 访问权限的同意。

Windows 10 有一个全局设置控制所有 Win32 应用程序的 microphonecamera 访问权限。对于 screen 以及在较旧版本的 Windows 上对于所有媒体类型,它将始终返回 granted

systemPreferences.askForMediaAccess(mediaType) macOS

  • mediaType string - 请求的媒体类型;可以是 microphonecamera

返回 Promise<boolean> - 一个 Promise,如果同意,则解析为 true,如果拒绝,则解析为 false。如果传递无效的 mediaType,则 Promise 将被拒绝。如果访问请求被拒绝,并且稍后通过系统偏好设置面板更改了权限,则需要重新启动应用程序才能使新权限生效。如果访问已被请求并拒绝,则 *必须* 通过偏好设置面板进行更改;不会弹出警报,并且 Promise 将以现有的访问状态解析。

重要: 为了正确利用此 API,您 必须在 应用程序的 Info.plist 文件中设置 NSMicrophoneUsageDescriptionNSCameraUsageDescription 字符串。这些键的值将用于填充权限对话框,以便用户能够正确了解权限请求的目的。有关如何在 Electron 环境中设置这些内容的更多信息,请参阅 Electron 应用程序分发

在 macOS 10.14 Mojave 之前不需要此用户同意,因此如果您的系统运行的是 10.13 High Sierra,此方法将始终返回 true

systemPreferences.getAnimationSettings()

返回 Object

  • shouldRenderRichAnimation boolean - 如果应渲染丰富的动画,则返回 true。查看会话类型(例如远程桌面)和可访问性设置,为重量级动画提供指导。
  • scrollAnimationsEnabledBySystem boolean - 基于每个平台确定是否应启用滚动动画(例如由 Home/End 键产生)。
  • prefersReducedMotion boolean - 根据平台 API 确定用户是否希望减少动画效果。

返回一个包含系统动画设置的对象。

属性

systemPreferences.accessibilityDisplayShouldReduceTransparency macOS 已废弃

一个 boolean 属性,确定应用程序是否避免使用半透明背景。这映射到 NSWorkspace.accessibilityDisplayShouldReduceTransparency

已废弃: 请使用新的 nativeTheme.prefersReducedTransparency API。

systemPreferences.effectiveAppearance macOS 只读

一个 string 属性,可以是 darklightunknown

返回当前应用于应用程序的 macOS 外观设置,映射到 NSApplication.effectiveAppearance