Chrome 的 webkitSpeechRecognition 随机结束

Chrome's webkitSpeechRecognition ends randomly

我正在使用 Web Speech API 在我的网页上捕获语音命令,但识别器在一段时间后结束(它停止侦听并触发 onend 事件)。

为什么会这样?我可以阻止它吗?

这是拥有语音识别页面(40 行)并重现错误所需的全部代码。当识别器停止侦听时,它会提醒 "end"。

<h1>Voice Recognizer</h1>

<script>

if (!('webkitSpeechRecognition' in window)) {
    alert('Your browser does not support speech recognition.');
} else {
    var recognition = new webkitSpeechRecognition();

    recognition.continuous = true;
    recognition.interimResults = true;

    recognition.onstart = function() {
        console.log('started');
    }

    recognition.onresult = function() { 
        interim_transcript = '';

        for (var i = event.resultIndex; i < event.results.length; ++i) {
            if (event.results[i].isFinal) {
                final_transcript += event.results[i][0].transcript;
            } else {
                interim_transcript += event.results[i][0].transcript;
            }
        }

        console.log('interim result:', interim_transcript);
        console.log('final reuslt:', final_transcript);
    }

    recognition.onerror = function() { alert('error'); }

    recognition.onend = function() { alert('end'); }

    function startListening(e){
        final_transcript = '';
        recognition.start();
    }

    startListening();
}

</script>

Google 试图限制处理的数据量,因为它加载了他们的服务器。结束后重新启动语音识别或使用一些离线处理,如 Pocketsphinx.JS

首先google目前已经给了60秒的录音时间,听力效率很高,所以建议你提高语速。如果您的演讲超过 60 秒,则 webkit 将触发 onspeechend() 函数,从而导致您的代码停止。无论哪种方式,如果您可以为 onspeechend() 编写自己的触发器并再次从内部调用您的函数,那么它应该适合您,因为它将启动一个新实例并继续您的文本,除非您清除它。