AudioWorklet 中的 new Function()
new Function() inside of AudioWorklet
我想创建一个音频编辑器,您可以在其中将节点连接在一起以创建自定义音频组件。每次节点更改时,它们都会被编译成 javascript,然后 运行 被 new Function()
编译以获得更好的性能。我刚读到有可能在单独的线程上创建 AudioWorklet
,运行。现在我想知道是否有可能将我的算法作为一串 javascript 代码传递给 AudioWorklet
,然后使用 new Function(codeString)
在构造函数内部。然后 audioworklet 的 process()
函数将以某种方式调用自定义函数。
这在某种程度上是可能的,还是我要求太多了?在我花几个小时试图让它工作之前,我想得到一个“是的,这是可能的”或“不,对不起”...
感谢您的帮助,
dogefromage
在@AKX 的评论的帮助下,我共同制作了这个解决方案。字符串中的代码稍后将被编译器替换。
function generateProcessor()
{
return (`
class TestProcessor extends AudioWorkletProcessor
{
process(inputs, outputs)
{
const input = inputs[0];
const output = outputs[0];
for (let channel = 0; channel < output.length; ++channel) {
for (let i = 0; i < output[channel].length; i++) {
output[channel][i] = 0.01 * Math.acos(input[channel][i]);
}
}
return true;
}
}
registerProcessor('test-processor', TestProcessor);
`);
}
const button = document.querySelector('#button');
button.addEventListener('click', async (e) =>
{
const audioContext = new AudioContext();
await audioContext.audioWorklet.addModule(
URL.createObjectURL(new Blob([
generateProcessor()
], {type: "application/javascript"})));
const oscillator = new OscillatorNode(audioContext);
const testProcessor = new AudioWorkletNode(audioContext, 'test-processor');
oscillator.connect(testProcessor).connect(audioContext.destination);
oscillator.start();
});
我想创建一个音频编辑器,您可以在其中将节点连接在一起以创建自定义音频组件。每次节点更改时,它们都会被编译成 javascript,然后 运行 被 new Function()
编译以获得更好的性能。我刚读到有可能在单独的线程上创建 AudioWorklet
,运行。现在我想知道是否有可能将我的算法作为一串 javascript 代码传递给 AudioWorklet
,然后使用 new Function(codeString)
在构造函数内部。然后 audioworklet 的 process()
函数将以某种方式调用自定义函数。
这在某种程度上是可能的,还是我要求太多了?在我花几个小时试图让它工作之前,我想得到一个“是的,这是可能的”或“不,对不起”...
感谢您的帮助,
dogefromage
在@AKX 的评论的帮助下,我共同制作了这个解决方案。字符串中的代码稍后将被编译器替换。
function generateProcessor()
{
return (`
class TestProcessor extends AudioWorkletProcessor
{
process(inputs, outputs)
{
const input = inputs[0];
const output = outputs[0];
for (let channel = 0; channel < output.length; ++channel) {
for (let i = 0; i < output[channel].length; i++) {
output[channel][i] = 0.01 * Math.acos(input[channel][i]);
}
}
return true;
}
}
registerProcessor('test-processor', TestProcessor);
`);
}
const button = document.querySelector('#button');
button.addEventListener('click', async (e) =>
{
const audioContext = new AudioContext();
await audioContext.audioWorklet.addModule(
URL.createObjectURL(new Blob([
generateProcessor()
], {type: "application/javascript"})));
const oscillator = new OscillatorNode(audioContext);
const testProcessor = new AudioWorkletNode(audioContext, 'test-processor');
oscillator.connect(testProcessor).connect(audioContext.destination);
oscillator.start();
});