首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >只用于自定义输出的AudioWorkletProcessor时间戳

只用于自定义输出的AudioWorkletProcessor时间戳
EN

Stack Overflow用户
提问于 2021-01-25 02:08:58
回答 1查看 83关注 0票数 0

我想建立一个非常低级别的音频输出节点使用网络音频API的AudioWorkletProcessor。似乎所有的例子都实现了将输入样本转换为输出样本的处理器,但我想做的是只生成输出,所有这些都是基于样本的时间戳。

根据MDN,BaseAudioContext.currentTime不是这个时间戳的精确来源:

为了防止定时攻击和指印,

的精度可能会根据浏览器设置而四舍五入。在火狐中,默认情况下,privacy.reduceTimerPrecision首选项是启用的,在Firefox59中默认为20 is,在60中为2ms。

一个棘手的解决方案可能是使用BaseAudioContext.sampleRate,一个正在运行的计数器,以及输出数组的大小,但是只有当我们可以假设每个样本都是在不下降的情况下计算,并且所有的计算都是按顺序进行的,而我不确定这些假设是否有效,这才能奏效。

在处理框架内,是否有可靠的方法知道与给定样本索引相关的时间戳?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-01-25 02:24:21

AudioWorkletGlobalScope内部,您可以访问currentTimecurrentFrame。它们都是全球性的。

https://webaudio.github.io/web-audio-api/#AudioWorkletGlobalScope-attributes

据我所知,它们在任何支持AudioWorklet的浏览器中都是准确的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65878106

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档