Merge pull request #326 from hecai84/main

添加任务栏缩略图控制按钮
This commit is contained in:
Alger
2025-06-20 17:49:09 +08:00
committed by GitHub
+46 -3
View File
@@ -1,5 +1,5 @@
import { is } from '@electron-toolkit/utils'; import { is } from '@electron-toolkit/utils';
import { app, BrowserWindow, globalShortcut, ipcMain, screen, session, shell } from 'electron'; import { app, BrowserWindow, nativeImage, globalShortcut, ipcMain, screen, session, shell } from 'electron';
import Store from 'electron-store'; import Store from 'electron-store';
import { join } from 'path'; import { join } from 'path';
import { import {
@@ -20,7 +20,7 @@ const store = new Store();
// 保存主窗口引用,以便在 activate 事件中使用 // 保存主窗口引用,以便在 activate 事件中使用
let mainWindowInstance: BrowserWindow | null = null; let mainWindowInstance: BrowserWindow | null = null;
let isPlaying = false;
// 保存迷你模式前的窗口状态 // 保存迷你模式前的窗口状态
let preMiniModeState: WindowState = { let preMiniModeState: WindowState = {
width: DEFAULT_MAIN_WIDTH, width: DEFAULT_MAIN_WIDTH,
@@ -56,6 +56,38 @@ function initializeProxy() {
} }
} }
function setThumbarButtons(window: BrowserWindow) {
window.setThumbarButtons([
{
tooltip: 'prev',
icon: nativeImage
.createFromPath(join(app.getAppPath(), 'resources/icons', 'prev.png')),
click() {
window.webContents.send('global-shortcut', 'prevPlay');
},
},
{
tooltip: isPlaying ? 'pause' : 'play',
icon: nativeImage
.createFromPath(join(app.getAppPath(), 'resources/icons', isPlaying ? 'pause.png' : 'play.png')),
click() {
window.webContents.send('global-shortcut', 'togglePlay');
},
},
{
tooltip: 'next',
icon: nativeImage
.createFromPath(join(app.getAppPath(), 'resources/icons', 'next.png')),
click() {
window.webContents.send('global-shortcut', 'nextPlay');
},
}
]);
}
/** /**
* 初始化窗口管理相关的IPC监听 * 初始化窗口管理相关的IPC监听
*/ */
@@ -189,6 +221,14 @@ export function initializeWindowManager() {
} }
}); });
ipcMain.on('update-play-state', (_, playing: boolean) => {
isPlaying = playing;
if (mainWindowInstance) {
setThumbarButtons(mainWindowInstance);
}
});
// 监听代理设置变化 // 监听代理设置变化
store.onDidChange('set.proxyConfig', () => { store.onDidChange('set.proxyConfig', () => {
initializeProxy(); initializeProxy();
@@ -250,6 +290,10 @@ export function createMainWindow(icon: Electron.NativeImage): BrowserWindow {
preMiniModeState = { ...savedState }; preMiniModeState = { ...savedState };
} }
mainWindow.on('show', () => {
setThumbarButtons(mainWindow);
});
mainWindow.on('ready-to-show', () => { mainWindow.on('ready-to-show', () => {
const [width, height] = mainWindow.getSize(); const [width, height] = mainWindow.getSize();
console.log(`窗口显示前的大小: ${width}x${height}`); console.log(`窗口显示前的大小: ${width}x${height}`);
@@ -261,7 +305,6 @@ export function createMainWindow(icon: Electron.NativeImage): BrowserWindow {
// 显示窗口 // 显示窗口
mainWindow.show(); mainWindow.show();
// 应用页面内容缩放 // 应用页面内容缩放
applyContentZoom(mainWindow); applyContentZoom(mainWindow);