无障碍功能
Electron 应用程序中的无障碍功能问题与网站的类似,因为它们最终都是 HTML。
手动启用无障碍功能
在存在辅助技术(例如,Windows 上的 JAWS 或 macOS 上的 VoiceOver)的情况下,Electron 应用程序将自动启用无障碍功能。有关更多详细信息,请参阅 Chrome 的无障碍功能文档。
您还可以在 Electron 应用程序中手动切换这些功能,或通过在第三方本机软件中设置标志来切换。
使用 Electron 的 API
通过使用 app.setAccessibilitySupportEnabled(enabled)
API,您可以在应用程序首选项中手动向用户公开 Chrome 的无障碍树。请注意,用户的系统辅助实用程序优先于此设置,并且会覆盖此设置。
在第三方软件中
macOS
在 macOS 上,第三方辅助技术可以通过编程方式设置 AXManualAccessibility
属性来切换 Electron 应用程序内部的无障碍功能
使用 Objective-C
CFStringRef kAXManualAccessibility = CFSTR("AXManualAccessibility");
+ (void)enableAccessibility:(BOOL)enable inElectronApplication:(NSRunningApplication *)app
{
AXUIElementRef appRef = AXUIElementCreateApplication(app.processIdentifier);
if (appRef == nil)
return;
CFBooleanRef value = enable ? kCFBooleanTrue : kCFBooleanFalse;
AXUIElementSetAttributeValue(appRef, kAXManualAccessibility, value);
CFRelease(appRef);
}
使用 Swift
import Cocoa
let name = CommandLine.arguments.count >= 2 ? CommandLine.arguments[1] : "Electron"
let pid = NSWorkspace.shared.runningApplications.first(where: {$0.localizedName == name})!.processIdentifier
let axApp = AXUIElementCreateApplication(pid)
let result = AXUIElementSetAttributeValue(axApp, "AXManualAccessibility" as CFString, true as CFTypeRef)
print("Setting 'AXManualAccessibility' \(error.rawValue == 0 ? "succeeded" : "failed")")