web-audio-api - WebAudio 的问题

标签 web-audio-api recorder.js

我正在创建一个研究实验,使用 WebAudio API 来记录用户所说的音频文件。 我使用 recorder.js 想出了一个解决方案,一切正常……直到我昨天尝试了。

我现在在 Chrome 中遇到这个错误:

"The AudioContext was not allowed to start. It must be resumed (or created) after a user gesture on the page."

它指的是这个链接:Web Audio API policy . 这似乎是上面链接中概述的 Chrome 新政策的结果。

所以我尝试像这样使用 resume() 来解决问题:

var gumStream; //stream from getUserMedia()
var rec; //Recorder.js object
var input; //MediaStreamAudioSourceNode we'll be recording

// shim for AudioContext when it's not avb. 
var AudioContext = window.AudioContext || window.webkitAudioContext;
var audioContext = new AudioContext; //new audio context to help us record

function startUserMedia() {
    var constraints = { audio: true, video:false };
    audioContext.resume().then(() => { // This is the new part
        console.log('context resumed successfully');
    });
    
    navigator.mediaDevices.getUserMedia(constraints).then(function(stream) {

        console.log("getUserMedia() success, stream created, initializing Recorder.js");
    gumStream = stream;
    input = audioContext.createMediaStreamSource(stream);
    rec = new Recorder(input, {numChannels:1});
    audio_recording_allowed = true;
    }).catch(function(err) {
        console.log("Error");
    });

}

现在在控制台中我得到:

错误

上下文恢复成功

并且流没有初始化。 这在 Firefox 和 Chrome 中都会发生。 我需要做什么?

最佳答案

我刚刚遇到了完全相同的问题!从技术上讲,您帮助我找到了这个答案。由于某种原因,我的错误消息不如您的完整,这些政策更改的链接有答案:)

最好的做法是在用户与文档交互后创建音频上下文,而不是恢复2018 年 9 月 28 日在 this thread 上,他在第一个要点中提到了原因)。

所以不是这个:

var audioContext = new AudioContext; //new audio context to help us record

function startUserMedia() {
    audioContext.resume().then(() => { // This is the new part
        console.log('context resumed successfully');
    });
}

只需像这样设置音频上下文:

var audioContext;

function startUserMedia() {
    if(!audioContext){
      audioContext = new AudioContext;
    } 
}

只要 startUserMedia() 在某种用户手势之后执行,这应该可以工作。

关于web-audio-api - WebAudio 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54110092/

相关文章:

html - 降低使用 recorderjs 创建的 WAV 文件的比特率

javascript - Recorder.js 录制未按预期工作

javascript - Typescript Web 音频 API 缺少定义

html - 通过 Web Audio API 使用分块音频进行断断续续/听不见的播放

javascript - 使用 Oscillator.connect() 和 Oscillator.disconnect() 方法在使用 Web Audio API 构建的应用程序中打开/关闭声音有多可行?

javascript - 如何将base64音频数据解码为wav格式

javascript - Android 版 Chrome 在重放录音时出现错误

javascript - 用于复杂播放列表的 Web Audio API 或 <audio>?

javascript - 使用 web-audio-api 的变调器?