-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.js
186 lines (156 loc) · 5.64 KB
/
main.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
'use strict';
// import {Menu, MenuItem, dialog, ipcMain} from 'electron';
// import {appMenuTemplate} from './src/component/menu';
const electron = require('electron');
// Module to control application life.
const app = electron.app;
const globalShortcut = electron.globalShortcut;
const appMenuTemplate = require('./src/menu').appMenuTemplate;
const Menu = electron.Menu;
const MenuItem = electron.MenuItem;
const dialog = electron.dialog;
const ipcMain = electron.ipcMain;
// Module to create native browser window.
const BrowserWindow = electron.BrowserWindow;
let safeExit = false;
// Keep a global reference of the window object, if you don't, the window will
// be closed automatically when the JavaScript object is garbage collected.
let mainWindow;
function createWindow() {
// Create the browser window.
mainWindow = new BrowserWindow({width: 800, height: 600});
// and load the index.html of the app.
mainWindow.loadURL('file://' + __dirname + '/dist/index.html');
// Open the DevTools.
// mainWindow.webContents.openDevTools();
const menu = Menu.buildFromTemplate(appMenuTemplate);
menu.items[0].submenu.append(new MenuItem({
label: "Open image file",
click() {
mainWindow.webContents.send('action', 'open'); //点击后向主页渲染进程发送“打开图片文件”的命令
},
accelerator: 'CmdOrCtrl+O' //快捷键:Ctrl+O
}));
menu.items[0].submenu.append(new MenuItem({
label: "Open ljson",
click() {
mainWindow.webContents.send('action', 'open_ljson'); //点击后向主页渲染进程发送“打开ljson文件”的命令
},
accelerator: 'CmdOrCtrl+Alt+O' //快捷键:Ctrl+Alt+O
}));
menu.items[0].submenu.append(new MenuItem({
label: "Save",
click() {
mainWindow.webContents.send('action', 'save'); //点击后向主页渲染进程发送“保存文件”的命令
},
accelerator: 'CmdOrCtrl+S' //快捷键:Ctrl+S
}));
//添加一个分隔符
menu.items[0].submenu.append(new MenuItem({
type: 'separator'
}));
menu.items[0].submenu.append(new MenuItem({
role: 'quit'
}));
menu.items[1].submenu.append(new MenuItem({
label: "Prev",
click() {
mainWindow.webContents.send('action', 'prev');
},
accelerator: 'Left'
}));
menu.items[1].submenu.append(new MenuItem({
label: "Prev10",
click() {
mainWindow.webContents.send('action', 'prev10');
},
accelerator: 'CmdOrCtrl+Left'
}));
menu.items[1].submenu.append(new MenuItem({
label: "Prev100",
click() {
mainWindow.webContents.send('action', 'prev100');
},
accelerator: 'Shift+Left'
}));
menu.items[1].submenu.append(new MenuItem({
label: "Next",
click() {
mainWindow.webContents.send('action', 'next');
},
accelerator: 'Right'
}));
menu.items[1].submenu.append(new MenuItem({
label: "Next10",
click() {
mainWindow.webContents.send('action', 'next10');
},
accelerator: 'CmdOrCtrl+Right'
}));
menu.items[1].submenu.append(new MenuItem({
label: "Next100",
click() {
mainWindow.webContents.send('action', 'next100');
},
accelerator: 'Shift+Right'
}));
menu.items[1].submenu.append(new MenuItem({
type: 'separator'
}));
menu.items[1].submenu.append(new MenuItem({
label: "Correct",
click() {
mainWindow.webContents.send('action', 'correct');
},
accelerator: 'Alt+,'
}));
menu.items[1].submenu.append(new MenuItem({
label: "Check InUse",
click() {
mainWindow.webContents.send('action', 'switch');
},
accelerator: 'Alt+.'
}));
Menu.setApplicationMenu(menu);
mainWindow.on('close', (e) => {
if (!safeExit) {
e.preventDefault();
mainWindow.webContents.send('action', 'exiting');
}
});
// Emitted when the window is closed.
mainWindow.on('closed', function () {
// Dereference the window object, usually you would store windows
// in an array if your app supports multi windows, this is the time
// when you should delete the corresponding element.
mainWindow = null;
});
}
// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
app.on('ready', createWindow);
// Quit when all windows are closed.
app.on('window-all-closed', function () {
// On OS X it is common for applications and their menu bar
// to stay active until the user quits explicitly with Cmd + Q
if (process.platform !== 'darwin') {
app.quit();
}
});
app.on('activate', function () {
// On OS X it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (mainWindow === null) {
createWindow();
}
});
ipcMain.on('reqaction', (event, arg) => {
switch (arg) {
case 'exit':
//做点其它操作:比如记录窗口大小、位置等,下次启动时自动使用这些设置;不过因为这里(主进程)无法访问localStorage,这些数据需要使用其它的方式来保存和加载,这里就不作演示了。这里推荐一个相关的工具类库,可以使用它在主进程中保存加载配置数据:https://github.com/sindresorhus/electron-store
//...
safeExit = true;
app.quit();//退出程序
break;
}
});