博客 / 詳情

返回

JavaScript的語音識別

有沒有想過給您的網站增添語音識別的功能?比如您的用户不用點鼠標,僅僅通過電腦或者手機的麥克風發佈命令,比如"下拉到頁面底部”,或者“跳轉到下一頁”,您的網站就會執行對應命令。聽起來很酷對麼?然而為了實現這個功能,必須得讓您網站的JavaScript腳本能夠識別到這些語音輸入。

這裏介紹一個開源的JavaScript語言輸入庫,名叫annyang。

Github地址:https://github.com/TalAter/an...

截至到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/an...

連粵語都支持,厲害了!

更多細節,請查閲annyang的官網。

https://www.talater.com/annyang/

要獲取更多Jerry的原創技術文章,請關注公眾號"汪子熙"或者掃描下面二維碼:

user avatar prepared 頭像
1 位用戶收藏了這個故事!

發佈 評論

Some HTML is okay.