-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathmain.js
157 lines (140 loc) · 4.13 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
// ============================ 公共模块 ============================
// electron模块
const electron = require('electron');
// 控制应用生命周期的模块。
const {app} = electron;
// 创建原生浏览器窗口的模块。
const {BrowserWindow} = electron;
// 通信进程
const {ipcMain} = electron;
// 弹出框
const {dialog} = electron;
// 快捷键
const {globalShortcut} = electron;
// 菜单
const {Menu} = electron;
// 托盘图标
const {Tray} = electron;
// ============================ 主窗口 ============================
// 保持一个对于 window 对象的全局引用,如果你不这样做,
// 当 JavaScript 对象被垃圾回收, window 会被自动地关闭。
let mainWindow;
// 防止多开
var shouldQuit = app.makeSingleInstance(function(commandLine, workingDirectory) {
// 当另一个实例运行的时候,这里将会被调用,我们需要激活应用的窗口
if (mainWindow) {
if (mainWindow.isMinimized()) {
mainWindow.restore();
}
mainWindow.focus();
// 传递启动参数
mainWindow.webContents.send('openFiles', commandLine);
}
return true;
});
// 这个实例是多余的实例,需要退出
if (shouldQuit) {
app.quit();
return;
}
function createWindow () {
// 创建浏览器窗口。
mainWindow = new BrowserWindow({
//width: 800,
//height: 600,
minWidth: 600,
minHeight: 600,
frame: false,
show: false,
webPreferences: {
defaultFontFamily: 'serif'
}
});
// 加载应用的 main.html。
mainWindow.loadURL(`file://${__dirname}/main.html`);
// 启用开发工具。
//mainWindow.webContents.openDevTools();
// 当 window 被关闭,这个事件会被触发。
mainWindow.on('closed', (event) => {
// 取消引用 window 对象,如果你的应用支持多窗口的话,
// 通常会把多个 window 对象存放在一个数组里面,
// 与此同时,你应该删除相应的元素。
mainWindow = null;
});
// 监听页面加载完毕后显示窗口
mainWindow.webContents.on('did-finish-load', (event) => {
mainWindow.show();
event.sender.send('openFiles', process.argv);
});
// 监听最大化按钮
mainWindow.on('maximize', (event) => {
event.sender.send('max');
});
mainWindow.on('unmaximize', (event) => {
event.sender.send('unmax');
});
}
// Electron 会在初始化后并准备创建浏览器窗口时,调用这个函数。
// 部分 API 在 ready 事件触发后才能使用。
app.on('ready', createWindow);
// 当全部窗口关闭时退出。
app.on('window-all-closed', () => {
// 在 macOS 上,除非用户用 Cmd + Q 确定地退出,
// 否则绝大部分应用及其菜单栏会保持激活。
if (process.platform !== 'darwin') {
app.quit();
}
});
// 当应用被激活时触发,常用于点击应用的 dock 图标的时候。macOS
app.on('activate', () => {
// 在 macOS 上,当点击 dock 图标并且该应用没有打开的窗口时,
// 绝大部分应用会重新创建一个窗口。
if (mainWindow === null) {
createWindow();
}
});
// 最小化
ipcMain.on('min', (event) => {
mainWindow.minimize();
});
// 最大化
ipcMain.on('max', (event) => {
if(mainWindow.isMaximized()) {
mainWindow.unmaximize();
} else {
mainWindow.maximize();
}
});
// 关闭
ipcMain.on('close', (event) => {
app.quit();
});
// ============================ 公共方法 ============================
// 通信方法:显示指定窗口
ipcMain.on('show', (event) => {
});
// 消息弹出框
ipcMain.on('showMessageBox', (event, options) => {
dialog.showMessageBox(options);
});
// ============================ 全局快捷键 ============================
app.on('ready', () => {
// 新建文件
globalShortcut.register('ctrl+n', function() {
mainWindow.webContents.send('newFile');
});
// 打开文件
globalShortcut.register('ctrl+o', function() {
mainWindow.webContents.send('open');
});
// 关闭当前文件
globalShortcut.register('ctrl+w', function() {
mainWindow.webContents.send('close');
});
});
app.on('will-quit', () => {
// 注销所有快捷键
globalShortcut.unregisterAll();
});
// 在这文件,你可以续写应用剩下主进程代码。
// 也可以拆分成几个文件,然后用 require 导入。