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
ready
event of the app module is emitted. Please also note that it is also possible to use Chromium'sGlobalShortcutsPortal
implementation, 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()
})
Méthodes
Le module globalShortcut
dispose des méthodes suivantes :
globalShortcut.register(accelerator, callback)
accelerator
Acceleratorcallback
Function
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)
accelerators
Accelerator[] - an array of Accelerators.callback
Function
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)
accelerator
Accelerator
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)
accelerator
Accelerator
Supprime le raccourci global de l'accelerator
.
globalShortcut.unregisterAll()
Supprime tous les raccourcis globaux.