2014-08-04 10:00:39 -06:00
|
|
|
# Accelerator
|
|
|
|
|
2016-04-21 16:39:12 -06:00
|
|
|
> Define keyboard shortcuts.
|
2016-04-21 16:35:29 -06:00
|
|
|
|
2021-11-15 21:13:18 -07:00
|
|
|
Accelerators are strings that can contain multiple modifiers and a single key code,
|
2016-10-26 06:48:09 -06:00
|
|
|
combined by the `+` character, and are used to define keyboard shortcuts
|
2024-01-04 08:06:12 -07:00
|
|
|
throughout your application. Accelerators are case insensitive.
|
2014-08-04 10:00:39 -06:00
|
|
|
|
|
|
|
Examples:
|
|
|
|
|
2016-04-01 15:09:01 -06:00
|
|
|
* `CommandOrControl+A`
|
|
|
|
* `CommandOrControl+Shift+Z`
|
2014-08-04 10:00:39 -06:00
|
|
|
|
2016-10-26 06:48:09 -06:00
|
|
|
Shortcuts are registered with the [`globalShortcut`](global-shortcut.md) module
|
|
|
|
using the [`register`](global-shortcut.md#globalshortcutregisteraccelerator-callback)
|
|
|
|
method, i.e.
|
|
|
|
|
2023-11-21 00:50:08 -07:00
|
|
|
```js
|
2018-09-13 10:10:51 -06:00
|
|
|
const { app, globalShortcut } = require('electron')
|
2016-10-26 06:48:09 -06:00
|
|
|
|
2020-02-03 15:43:22 -07:00
|
|
|
app.whenReady().then(() => {
|
2016-10-26 06:48:09 -06:00
|
|
|
// Register a 'CommandOrControl+Y' shortcut listener.
|
|
|
|
globalShortcut.register('CommandOrControl+Y', () => {
|
|
|
|
// Do stuff when Y and either Command/Control is pressed.
|
|
|
|
})
|
|
|
|
})
|
|
|
|
```
|
|
|
|
|
2014-08-04 10:00:39 -06:00
|
|
|
## Platform notice
|
|
|
|
|
2015-07-23 10:55:57 -06:00
|
|
|
On Linux and Windows, the `Command` key does not have any effect so
|
2016-06-18 07:26:26 -06:00
|
|
|
use `CommandOrControl` which represents `Command` on macOS and `Control` on
|
2014-08-04 10:00:39 -06:00
|
|
|
Linux and Windows to define some accelerators.
|
|
|
|
|
2016-06-18 07:26:26 -06:00
|
|
|
Use `Alt` instead of `Option`. The `Option` key only exists on macOS, whereas
|
2016-04-01 16:48:12 -06:00
|
|
|
the `Alt` key is available on all platforms.
|
|
|
|
|
2021-05-18 18:52:06 -06:00
|
|
|
The `Super` (or `Meta`) key is mapped to the `Windows` key on Windows and Linux and
|
2016-06-18 07:26:26 -06:00
|
|
|
`Cmd` on macOS.
|
2015-04-27 23:28:18 -06:00
|
|
|
|
2014-08-04 10:00:39 -06:00
|
|
|
## Available modifiers
|
|
|
|
|
|
|
|
* `Command` (or `Cmd` for short)
|
|
|
|
* `Control` (or `Ctrl` for short)
|
|
|
|
* `CommandOrControl` (or `CmdOrCtrl` for short)
|
|
|
|
* `Alt`
|
2016-03-05 23:12:04 -07:00
|
|
|
* `Option`
|
|
|
|
* `AltGr`
|
2014-08-04 10:00:39 -06:00
|
|
|
* `Shift`
|
2015-04-27 23:28:18 -06:00
|
|
|
* `Super`
|
2021-05-18 18:52:06 -06:00
|
|
|
* `Meta`
|
2014-08-04 10:00:39 -06:00
|
|
|
|
|
|
|
## Available key codes
|
|
|
|
|
|
|
|
* `0` to `9`
|
|
|
|
* `A` to `Z`
|
|
|
|
* `F1` to `F24`
|
2023-06-13 04:42:55 -06:00
|
|
|
* Various Punctuation: `)`, `!`, `@`, `#`, `$`, `%`, `^`, `&`, `*`, `(`, `:`, `;`, `:`, `+`, `=`, `<`, `,`, `_`, `-`, `>`, `.`, `?`, `/`, `~`, `` ` ``, `{`, `]`, `[`, `|`, `\`, `}`, `"`
|
2015-01-23 16:26:54 -07:00
|
|
|
* `Plus`
|
2014-08-04 10:00:39 -06:00
|
|
|
* `Space`
|
2016-05-12 14:00:58 -06:00
|
|
|
* `Tab`
|
2019-02-04 16:54:59 -07:00
|
|
|
* `Capslock`
|
|
|
|
* `Numlock`
|
2019-02-11 12:13:13 -07:00
|
|
|
* `Scrolllock`
|
2014-08-04 10:00:39 -06:00
|
|
|
* `Backspace`
|
|
|
|
* `Delete`
|
|
|
|
* `Insert`
|
|
|
|
* `Return` (or `Enter` as alias)
|
|
|
|
* `Up`, `Down`, `Left` and `Right`
|
|
|
|
* `Home` and `End`
|
|
|
|
* `PageUp` and `PageDown`
|
|
|
|
* `Escape` (or `Esc` for short)
|
|
|
|
* `VolumeUp`, `VolumeDown` and `VolumeMute`
|
|
|
|
* `MediaNextTrack`, `MediaPreviousTrack`, `MediaStop` and `MediaPlayPause`
|
2016-03-05 23:12:04 -07:00
|
|
|
* `PrintScreen`
|
2018-11-14 12:02:18 -07:00
|
|
|
* NumPad Keys
|
|
|
|
* `num0` - `num9`
|
|
|
|
* `numdec` - decimal key
|
|
|
|
* `numadd` - numpad `+` key
|
|
|
|
* `numsub` - numpad `-` key
|
|
|
|
* `nummult` - numpad `*` key
|
|
|
|
* `numdiv` - numpad `÷` key
|