globalShortcut
Détecte les événements de clavier lorsque l'application n'a pas le focus du clavier.
Process: Main
Le module globalShortcut peut inscrire/désinscrire un raccourci clavier global avec le système d'exploitation afin que vous puissiez personnaliser les opérations pour les différents raccourcis.
[!NOTE] The shortcut is global; it will work even if the app does not have the keyboard focus. This module cannot be used before the
readyevent of the app module is emitted. Please also note that it is also possible to use Chromium'sGlobalShortcutsPortalimplementation, which allows apps to bind global shortcuts when running within a Wayland session.
const { app, globalShortcut } = require('electron')
// Enable usage of Portal's globalShortcuts. This is essential for cases when
// the app runs in a Wayland session.
app.commandLine.appendSwitch('enable-features', 'GlobalShortcutsPortal')
app.whenReady().then(() => {
// Register a 'CommandOrControl+X' shortcut listener.
const ret = globalShortcut.register('CommandOrControl+X', () => {
console.log('CommandOrControl+X is pressed')
})
if (!ret) {
console.log('enregistrement échoué')
}
// Check si le raccourci est enregistré.
console.log(globalShortcut.isRegistered('CommandOrControl+X'))
})
app.on('will-quit', () => {
// Retire le raccourci.
globalShortcut.unregister('CommandOrControl+X')
// Supprime tous les raccourcis.
globalShortcut.unregisterAll()
})
[!TIP] See also: A detailed guide on Keyboard Shortcuts.
Méthodes
Le module globalShortcut dispose des méthodes suivantes :
globalShortcut.register(accelerator, callback)
acceleratorstring - An accelerator shortcut.callbackFunction
Retourne boolean - Si le raccourci a été enregistré avec succès.
Enregistre un raccourci global correspondant à accelerator. La callback est appelée lorsque le raccourci enregistré est saisi par l'utilisateur.
Lorsque l'accélérateur est déjà utilisé par d'autres applications, cet appel échouera silencieusement. Ce comportement est prévu par les systèmes d'exploitation, car ils ne veulent pas que les applications se battent pour des raccourcis globaux.
The following accelerators will not be registered successfully on macOS 10.14 Mojave unless the app has been authorized as a trusted accessibility client:
- "Media Play/Pause"
- "Media Piste Suivante"
- "Media Piste Précédente"
- "Media Stop"
globalShortcut.registerAll(accélérateurs, callback)
acceleratorsstring[] - An array of accelerator shortcuts.callbackFunction
Enregistre un raccourci global pour chaque élément accelerator de accelerators. La callback est appelée lorsque l'un des raccourcis enregistrés est saisi par l'utilisateur.
Lorsqu'un accélérateur donné est déjà pris par d'autres applications, cet appel échouera silencieusement. Ce comportement est prévu par les systèmes d'exploitation, car ils ne veulent pas que les applications se battent pour des raccourcis globaux.
The following accelerators will not be registered successfully on macOS 10.14 Mojave unless the app has been authorized as a trusted accessibility client:
- "Media Play/Pause"
- "Media Piste Suivante"
- "Media Piste Précédente"
- "Media Stop"
globalShortcut.isRegistered(accelerator)
acceleratorstring - An accelerator shortcut.
Retourne un boolean - Si l'application à enregistrer l'accelerator.
Lorsque l'accelerator est déjà utilisé par d'autres applications, cet appel retournera toujours false. Ce comportement est prévu par les systèmes d'exploitation, car ils ne veulent pas que les applications se battent pour des raccourcis globaux.
globalShortcut.unregister(accelerator)
acceleratorstring - An accelerator shortcut.
Supprime le raccourci global de l'accelerator.
globalShortcut.unregisterAll()
Supprime tous les raccourcis globaux.