我目前正在学习语音识别(JavaScript(。
我想用JavaScript做一个助手。我的问题是,我说的每一句话都不能用。当我说Hello时,我希望它能启动函数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();
您忘记在recognition.onresult
回调中调用tsCheck()
函数。
recognition.onresult = function(event) {
var current = event.resultIndex;
window.transcript = event.results[current][0].transcript;
tsCheck(); //ADD THIS
console.log(window.transcript);
}
EDIT:在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");
}
}
还使用正则表达式测试字符串,因为它有时在单词前后有空格。