mme*_*nde 4 javascript electron web-audio-api
我正在尝试在我的电子应用程序中使用 AudioWorklet 进行计量等。在开发模式下执行时工作正常,其中工作集由快速开发服务器(如http://localhost:3000/processor.js )提供服务。但是,如果我尝试在 prod 模式下运行该应用程序,该文件将在本地提供,例如 file://tmp/etc/etc/build/processor.js 并且在开发人员控制台中,我什至可以正确地看到该文件正在预览,但我收到此错误消息:
Uncaught (in promise) DOMException: 用户中止了一个请求。
我在这里之前看到其他人也有类似的问题,但不幸的是,我在堆栈溢出方面的声誉不够高,无法直接发表评论。将 mime-type 更改为 application/javascript 或 text/javascript 的建议听起来不错,但我不知道如何强制电子对特定文件使用特定的 mime 类型。此外,在网络选项卡的开发人员控制台中,似乎 Chrome 实际上已经为我的 processor.js 假设了一个 javascript 文件。
我已经尝试使用这样的自定义协议加载工作集
protocol.registerStandardSchemes(['worklet']);
app.on('ready', () => {
protocol.registerHttpProtocol('worklet', (req, cb) => {
fs.readFile(req.url.replace('worklet://', ''), (err, data) => {
cb({ mimeType: 'text/javascript', data });
});
});
});
Run Code Online (Sandbox Code Playgroud)
然后在添加工作集时
await ctx.audioWorklet.addModule('worklet://processor.js');
Run Code Online (Sandbox Code Playgroud)
不幸的是,这只会以这些错误结束,然后是第一个错误
GET worklet://processor.js/ 0 ()
未捕获错误:您提供的错误不包含堆栈跟踪。
...
如果有人感兴趣,我找到了一个hacky解决方案。为了强制使用 mime 类型的电子/铬,我很高兴我将文件 api 作为字符串加载工作集文件,将其转换为带有 mime 类型文本/javascript 的 blob,然后从中创建一个对象 url
const processorPath = isDevMode ? 'public/processor.js' : `${global.__dirname}/processor.js`;
const processorSource = await readFile(processorPath); // just a promisified version of fs.readFile
const processorBlob = new Blob([processorSource.toString()], { type: 'text/javascript' });
const processorURL = URL.createObjectURL(processorBlob);
await ctx.audioWorklet.addModule(processorURL);
Run Code Online (Sandbox Code Playgroud)
希望这可以帮助任何有同样问题的人......
| 归档时间: |
|
| 查看次数: |
1185 次 |
| 最近记录: |