有沒有想過給您的網站增添語音識別的功能?比如您的用戶不用點鼠標,僅僅通過電腦或者手機的麥克風發布命令,比如"下拉到頁面底部”,或者“跳轉到下一頁”,您的網站就會執行對應命令。聽起來很酷對么?然而為了實現這個功能,必須得讓您網站的JavaScript腳本能夠識別到這些語音輸入。
這里介紹一個開源的JavaScript語言輸入庫,名叫annyang。
Github地址:https://github.com/TalAter/annyang
截至到2018年7月12日,這個github倉庫已經有4833個Star了。
annyang實際上就是一個只有2KB大小的JavaScript腳本文件,使用起來非常方便。
下面就跟着我一起做一個Hello World應用吧,看看您通過麥克風說話的聲音是如何被這個JavaScript庫文件識別到的。
新建一個html文件,將下面的代碼復制進去。將它部署到您本地的Tomcat或者nodejs服務器上。
<html>
<script src="annyang.min.js"></script>
<script>
if (annyang) {
var commands = {
"Hello": function() {
alert(" I have heard your voice!");
}
};
var commands2 = {
"Bye": function(){
alert("再見!");
}
}
annyang.addCommands(commands);
annyang.addCommands(commands2);
annyang.start();
}
</script>
</html>
我測試用的是Chrome。
當您第一次在瀏覽器里訪問這個網頁時,會彈出下面的Chrome對話框,提示您這個應用要使用您電腦上的麥克風。點Allow按鈕即可。
這個應用有兩個地方向您提示它可以接受語音輸入。第一處是下圖1的紅色小圓圈。
第二處是一個小的麥克風圖標,點擊之后,可以設置允許或者禁止麥克風。我們當然是要選擇允許啦,否則如何接受語音輸入呢?
如果您的筆記本電腦本身也有麥克風,可以從這個下拉菜單里選擇用筆記本自帶的麥克風,還是用外接的麥克風。我用的是后者。
現在可以測試了。
因為代碼里我給Hello這個語音綁定的執行函數是一個alert彈出對話框,所以當我對着麥克風說了一句“Hello"之后,我的瀏覽器立即彈出了這個對話框。
同樣,說了"Bye"后,會彈出“再見”。我在響應“Bye”這個語音的函數設置了一個斷點,大家通過調用棧也可以觀察到annyang的處理邏輯。
從annyang的github上能看出,中文也在支持的語音之列,所以大家放心大膽地使用吧!
https://github.com/TalAter/annyang/blob/master/docs/FAQ.md
連粵語都支持,厲害了!
更多細節,請查閱annyang的官網。
https://www.talater.com/annyang/
要獲取更多Jerry的原創技術文章,請關注公眾號"汪子熙"或者掃描下面二維碼: