Aller au contenu principal

Tray

Vue d'ensemble

Ce guide vous guidera tout au long du processus de création d’une icône de la barre d’état avec son propre menu contextuel dans la zone de notification du système.

Sur MacOS et Ubuntu, la zone de notification sera située dans le coin supérieur droit de l'écran, à coté des icônes batterie et wifi. Sous Windows, la barre d'états se trouve généralement dans le coin inférieur droit.

Example

main.js

Nous devons d’abord importer app, Tray, Menu, nativeImage depuis electron.

const { app, Tray, Menu, nativeImage } = require('electron')

Ensuite, nous allons créer notre Tray. Pour ce faire, nous utiliserons une icône NativeImage , qui peut être créée via l’une de ces méthodes. Notez que nous encapsulons notre code de création du Tray dans un app.whenReady car nous devrons attendre que notre application electron termine de s'initialiser.

main.js
let tray

app.whenReady().then(() => {
const icon = nativeImage.createFromPath('path/to/asset.png')
tray = new Tray(icon)

// note: votre code contextMenu, Tooltip and Title ira ici!
})

Génial! Maintenant nous pouvons commencer à attacher un menu contextuel à notre Tray, comme ceci:

const contextMenu = Menu.buildFromTemplate([
{ label: 'Item1', type: 'radio' },
{ label: 'Item2', type: 'radio' },
{ label: 'Item3', type: 'radio', checked: true },
{ label: 'Item4', type: 'radio' }
])

tray.setContextMenu(contextMenu)

Le code ci-dessus créera 4 éléments distincts de type radio dans le menu contextuel. Pour en savoir plus sur la création de menus natifs, cliquez sur ce lien ici.

Enfin, donnons à notre barre d’états une infobulle et un titre.

tray.setToolTip('Ceci est mon application')
tray.setTitle('Ceci est mon titre')

Conclusion

Après avoir démarré votre application electron, vous devriez voir le Tray placé en soit haut soit en bas à droite de votre écran, selon votre système d'exploitation. fiddle docs/latest/fiddles/native-ui/tray