添加32位打包和日志

This commit is contained in:
yuchenglong
2025-11-20 11:20:10 +08:00
parent 2406d600ef
commit 5bdcc7f303
91 changed files with 113 additions and 121774 deletions

View File

@@ -1,31 +1,53 @@
const { app, BrowserWindow, ipcMain } = require('electron');
const path = require('path');
const { Worker } = require('worker_threads');
const { app, BrowserWindow, ipcMain } = require("electron");
const path = require("path");
const { Worker } = require("worker_threads");
const log = require("electron-log");
// 配置日志输出
log.transports.file.level = "info";
log.transports.file.resolvePath = () =>
path.join(path.dirname(app.getPath("exe")), "logs", "main.log");
log.info("App starting...");
// 监听渲染进程日志
ipcMain.on("log-message", (event, { level, message }) => {
if (log[level]) {
log[level](`[Renderer] ${message}`);
} else {
log.info(`[Renderer] ${message}`);
}
});
let idCardWorker = null;
let mainWindow = null;
function createIdCardWorker() {
if (idCardWorker) return;
idCardWorker = new Worker(path.join(__dirname, 'idcard-worker.js'));
idCardWorker.on('message', (msg) => {
log.info("Creating IDCard Worker...");
idCardWorker = new Worker(path.join(__dirname, "idcard-worker.js"));
idCardWorker.on("message", (msg) => {
if (!mainWindow) return;
if (msg.type === 'data') {
mainWindow.webContents.send('idcard-data', { payload: msg.payload });
} else if (msg.type === 'error') {
mainWindow.webContents.send('idcard-error', { payload: msg.payload });
if (msg.type === "data") {
log.info("IDCard data received");
mainWindow.webContents.send("idcard-data", { payload: msg.payload });
} else if (msg.type === "error") {
log.error("IDCard worker error message:", msg.payload);
mainWindow.webContents.send("idcard-error", { payload: msg.payload });
} else if (msg.type === "log") {
log.info("[Worker]", msg.payload);
}
});
idCardWorker.on('error', (err) => {
console.error('Worker error:', err);
idCardWorker.on("error", (err) => {
log.error("Worker thread error:", err);
});
idCardWorker.on('exit', (code) => {
if (code !== 0) console.error(`Worker stopped with exit code ${code}`);
idCardWorker.on("exit", (code) => {
if (code !== 0) log.error(`Worker stopped with exit code ${code}`);
else log.info("Worker stopped gracefully");
idCardWorker = null;
});
}
@@ -35,24 +57,24 @@ function createWindow() {
width: 1080,
height: 1920,
webPreferences: {
preload: path.join(__dirname, 'preload.js'),
preload: path.join(__dirname, "preload.js"),
nodeIntegration: false,
contextIsolation: true,
},
});
mainWindow = win;
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><C2BC><EFBFBD> Vite <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ַ
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><C2BC>ش<EFBFBD><D8B4><EFBFBD><EFBFBD><EFBFBD> index.html
const isDev = !app.isPackaged;
if (isDev) {
win.loadURL('http://localhost:5173');
win.loadURL("http://localhost:5173");
// <20>򿪿<EFBFBD><F2BFAABF><EFBFBD><EFBFBD>߹<EFBFBD><DFB9><EFBFBD>
win.webContents.openDevTools();
} else {
win.loadFile(path.join(__dirname, '../dist/index.html'));
win.loadFile(path.join(__dirname, "../dist/index.html"));
}
}
@@ -61,35 +83,35 @@ app.whenReady().then(() => {
createIdCardWorker();
// IPC <20><><EFBFBD><EFBFBD>
ipcMain.handle('start_idcard_listen', () => {
ipcMain.handle("start_idcard_listen", () => {
if (idCardWorker) {
idCardWorker.postMessage('start');
idCardWorker.postMessage("start");
} else {
createIdCardWorker();
idCardWorker.postMessage('start');
idCardWorker.postMessage("start");
}
return 'started';
return "started";
});
ipcMain.handle('stop_idcard_listen', () => {
ipcMain.handle("stop_idcard_listen", () => {
if (idCardWorker) {
idCardWorker.postMessage('stop');
idCardWorker.postMessage("stop");
}
return 'stopped';
return "stopped";
});
app.on('activate', () => {
app.on("activate", () => {
if (BrowserWindow.getAllWindows().length === 0) {
createWindow();
}
});
});
app.on('window-all-closed', () => {
app.on("window-all-closed", () => {
if (idCardWorker) {
idCardWorker.terminate();
}
if (process.platform !== 'darwin') {
if (process.platform !== "darwin") {
app.quit();
}
});