fix(lyric): 修复桌面歌词窗口首次打开无歌词问题

歌词窗口 Vue 加载完成后发送 lyric-ready 信号,主窗口收到后
发送完整歌词数据,替代不可靠的延迟猜测方案
This commit is contained in:
alger
2026-03-12 18:31:16 +08:00
parent 1c222971d5
commit 479db66eb0
6 changed files with 28 additions and 3 deletions

View File

@@ -172,6 +172,13 @@ export const loadLyricWindow = (ipcMain: IpcMain, mainWin: BrowserWindow): void
});
});
// 歌词窗口 Vue 应用加载完成,通知主窗口发送完整歌词数据
ipcMain.on('lyric-ready', () => {
if (mainWin && !mainWin.isDestroyed()) {
mainWin.webContents.send('lyric-window-ready');
}
});
ipcMain.on('send-lyric', (_, data) => {
if (lyricWindow && !lyricWindow.isDestroyed()) {
try {

View File

@@ -19,6 +19,7 @@ interface API {
sendSong: (data: any) => void;
unblockMusic: (id: number, data: any, enabledSources?: string[]) => Promise<any>;
onLyricWindowClosed: (callback: () => void) => void;
onLyricWindowReady: (callback: () => void) => void;
getAppUpdateState: () => Promise<AppUpdateState>;
checkAppUpdate: (manual?: boolean) => Promise<AppUpdateState>;
downloadAppUpdate: () => Promise<AppUpdateState>;

View File

@@ -28,6 +28,10 @@ const api = {
onLyricWindowClosed: (callback: () => void) => {
ipcRenderer.on('lyric-window-closed', () => callback());
},
// 歌词窗口就绪事件Vue 加载完成,可以接收数据)
onLyricWindowReady: (callback: () => void) => {
ipcRenderer.on('lyric-window-ready', () => callback());
},
getAppUpdateState: () => ipcRenderer.invoke('app-update:get-state') as Promise<AppUpdateState>,
checkAppUpdate: (manual = false) =>
ipcRenderer.invoke('app-update:check', { manual }) as Promise<AppUpdateState>,

View File

@@ -821,9 +821,11 @@ export const openLyric = () => {
sendLyricToWin();
}
// 设置定时器确保500ms后再次发送数据,以防窗口加载延迟
// 延迟重发一次,以防窗口加载略慢
setTimeout(() => {
sendLyricToWin();
if (isLyricWindowOpen.value) {
sendLyricToWin();
}
}, 500);
// 启动歌词同步
@@ -936,11 +938,17 @@ export const initAudioListeners = async () => {
// 初始化音频监听器
setupAudioListeners();
// 监听歌词窗口关闭事件
// 监听歌词窗口事件
if (isElectron) {
window.api.onLyricWindowClosed(() => {
isLyricWindowOpen.value = false;
});
// 歌词窗口 Vue 加载完成后,发送完整歌词数据
window.api.onLyricWindowReady(() => {
if (isLyricWindowOpen.value) {
sendLyricToWin();
}
});
}
// 获取最新的音频实例

View File

@@ -12,6 +12,8 @@ export interface IElectronAPI {
unblockMusic: (_id: number) => Promise<string>;
importCustomApiPlugin: () => Promise<{ name: string; content: string } | null>;
importLxMusicScript: () => Promise<{ name: string; content: string } | null>;
onLyricWindowClosed: (_callback: () => void) => void;
onLyricWindowReady: (_callback: () => void) => void;
onLanguageChanged: (_callback: (_locale: string) => void) => void;
store: {
get: (_key: string) => Promise<any>;

View File

@@ -642,6 +642,9 @@ onMounted(() => {
console.error('Error parsing lyric data:', error);
}
});
// 通知主窗口歌词窗口已就绪,请求发送完整歌词数据
windowData.electron.ipcRenderer.send('lyric-ready');
});
onUnmounted(() => {