我有一个电子应用程序(带有 Angular)。
我是 Electron 和所有这些进程间事件处理的新手。
我的问题是我有这个 ipcMain 处理程序(主进程)(我从 Angular 服务“调用”):
ipcMain.handle('video-audio-merge', (event, filename) => {
return new Promise((resolve) => {
new FFmpeg(filename+'.mp4').addInput(filename+'.mp3')
.on('progress', progress => resolve(progress.percent)) // The problem is in this line
.save('merged_'+filename+'.mp4')
.on('end', () => resolve(100));
});
})
我想要实现的是跟踪视频和音频合并的进度(可能需要几秒钟到几分钟)。但这里的问题是,一旦 Promise 被解决,它就不会发送下一个进度值(我最终会收到 3%,然后即使“合并”仍在进行中,也不会收到任何其他值)。
然后我尝试了以下(主要过程)(我无法编译):
const Observable = require('rxjs');
...
ipcMain.handle('video-audio-merge', (event, filename) => {
return new Promise((resolve) => {
resolve( // Will resolve to an Observable that will be able to provide progress values
new Observable<number>(subscriber => {
new FFmpeg(filename+'.mp4').addInput(filename+'.mp3')
.on('progress', progress => subscriber.next(progress.percent)) // Streaming progress values
.save('merged_'+filename+'.mp4')
.on('end', () => subscriber.completed());
}) // End Observable
); // End Resolve
}); // End Promise
}) // End ipcMain.handle
我添加了评论来解释我想要实现的目标。在我的 Angular 服务中,我正在调用这个处理程序,如下所示:
const electron = (<any>window).require('electron');
import { Observable } from 'rxjs';
...
electron.ipcRenderer.invoke('video-audio-merge', filename).then((subscriber: Observable<number>) => { // This should resolve to my Observable
subscriber.subscribe((progress: number) => { // I subscribe to the Observable to get progress values
console.log(progress); // here I should be using my progress value
});
});
编译时出现以下错误:
A JavaScript error occurred in the main process
Uncaught Exception:
Error: Cannot find module 'rxjs-compat'
我相信还有其他一些“优雅”的方法可以在 Main 和 Renderer 进程之间实现这种行为,如果你能引导我找到任何我将不胜感激的方法。
否则,你能帮我解决这个错误吗?或者与我分享我可以阅读什么来学习如何在 Electron 中使用“Observables”。