我目前正在学习语音识别(JavaScript)。
我想和JavaScript做个助理。我的问题是我说的每句话我都不能用。当我说你好时,我希望它启动ai()函数。
我的守则:
function tsCheck(){
if (window.transcript == "Hi"){
ai();
}
}
function speak(a){
var msg = new SpeechSynthesisUtterance(a);
window.speechSynthesis.speak(msg);
}
function ai(){
speak('How are you?');
if (window.transcript == "good"){
speak("cool");
}
}
var SpeechRecognition = window.SpeechRecognition || window.webkitSpeechRecognition;
var recognition = new SpeechRecognition();
recognition.continuous = true;
recognition.onresult = function(event) {
var current = event.resultIndex;
window.transcript = event.results[current][0].transcript;
console.log(window.transcript);
}
recognition.start();
发布于 2018-11-27 15:42:57
忘记在tsCheck()
回调中调用recognition.onresult
函数。
recognition.onresult = function(event) {
var current = event.resultIndex;
window.transcript = event.results[current][0].transcript;
tsCheck(); //ADD THIS
console.log(window.transcript);
}
编辑:在tsCheck
方法中,需要将结果与小写字符串进行比较(注意"Hi“而不是"hi”)。
function tsCheck(){
if (window.transcript == "hi"){
ai();
}
}
编辑2:为了保持对输入的响应,我向ai()
函数添加了一个参数。然而,这并不是真正的实际用途,因为它没有跟踪对话的上下文。
function ai(string){
speak(string);
}
function tsCheck(){
if (/hi/i.test(window.transcript)){
ai("How are you");
}
if (/good/i.test(window.transcript)){
ai("Cool");
}
}
还使用regex测试字符串,因为它有时在单词前后有空格。
https://stackoverflow.com/questions/53503080
复制相似问题