Electron - własne menu

Autor podstrony: Krzysztof Zajączkowski

Stronę tą wyświetlono już: 517 razy

Defultowe menu nie za bardzo się przydaje, no chyba tylko jako pokazówka. Warto więc jest obczaić jak dodać własne menu oraz własne skróty klawiaturowe! Oto prosty przykład kodu z dodanym menu:

/** importowanie instanji aplikacji i klasy BrowserWindow umożliwiającej * tworzenie nowego okna programu oraz obiektu menu */ const { app, BrowserWindow, Menu } = require("electron"); // ustawia produkcyjną wersję process.env.NODE_ENV = 'dev'; // 'production'; let win /** * Funkcja tworząca okno programu */ function createWindow() { win = new BrowserWindow({ width: 800, height: 600, webPreferences: { nodeIntegration: true, }, }); /** * Tutaj wskazywany jest plik widoku okna */ win.loadFile("index.html"); /** * Tworzenie menu */ const mainMenu = Menu.buildFromTemplate(mainMenuTemplate); /** * Dodanie menu do okna */ Menu.setApplicationMenu(mainMenu); } /** * Gdy aplikacja jest gotowa można utworzyć okno programu */ app.whenReady().then(createWindow); /** * Na zdarzenie zamknięcia wszystkich okien programu należy zakończyć * żywot programu */ app.on("window-all-closed", () => { if (process.platform !== "darwin") { app.quit(); } }); /** * Gdy program jest aktywowany a liczba okien jest równa 0 to utwórz okno programu */ app.on("activate", () => { if (BrowserWindow.getAllWindows().length === 0) { createWindow(); } }); const mainMenuTemplate = [ { label: "Program", submenu: [ { label: "Zamknij", accelerator: process.platform === "darwin" ? "Command+Q" : "Ctrl+Q", click() { app.quit(); }, }, ], }, ]; // jeżeli mac to dodaj pusty obiekt do menu, żeby się poprawnie wyświeltało if (process.platform === "darwin") { mainMenuTemplate.unshift({}); } // dodaj narzędzia deweloperskie, jeżeli nie jesteś w trybie deweloperskim if (process.env.NODE_ENV !== 'production') { mainMenuTemplate.push( { label: 'Developer tools', submenu: [ { label: 'Toogle dev tools', accelerator: process.platform === "darwin" ? "Command+I" : "Ctrl+I", click( item, focusedWindow ) { win.webContents.openDevTools() } } ] } ) }
Electron - dodanie własnego menu
Rys. 1
Electron - dodanie własnego menu
Strony powiązane
strony powiązane
  1. github.com/Obliczeniowo/Electron-basic-project - gałąź repozytorium zawierająca menu
Propozycje książek