基于語(yǔ)音識別的聲控鼠標的設計方法
摘要: 實(shí)現了一種基于語(yǔ)音識別技術(shù)的聲控鼠標光標應用程序, 可以用語(yǔ)音控制鼠標光標移動(dòng)到屏幕的任意位置, 能用來(lái)幫助傷殘人士只用聲音而不用鼠標和鍵盤(pán)就能操作電腦。分析了語(yǔ)音控制鼠標光標使用過(guò)程中的延時(shí)缺陷, 并做出了針對性的改進(jìn)。
本文引用地址:http://dyxdggzs.com/article/165091.htm1 概述
電腦語(yǔ)音技術(shù)經(jīng)過(guò)多年發(fā)展已經(jīng)取得了巨大進(jìn)步, 目前已經(jīng)有一些產(chǎn)品和項目讓人們有機會(huì )和計算機進(jìn)行語(yǔ)音交互工作, 例如IBM公司的Viavoice 系列軟件以及微軟的新的Office 產(chǎn)品都有實(shí)用的語(yǔ)音功能, 可以進(jìn)行語(yǔ)音聽(tīng)寫(xiě)錄入文字等工作, 還出現了一些基于語(yǔ)音技術(shù)的應用系統。
語(yǔ)音技術(shù)特別是語(yǔ)音識別技術(shù)的發(fā)展, 使人們可能實(shí)現用語(yǔ)音控制電腦, 這對于世界上眾多不能方便使用傳統的鼠標及鍵盤(pán)的傷殘人士有重大的意義; 另外在一些場(chǎng)合不方便操作電腦但又必須使用的情況下同樣很有意義, 比如駕駛的同時(shí)查詢(xún)電子地圖。目前要真正控制一臺圖形界面的電腦, 必須做到使用語(yǔ)音控制也能像使用鍵盤(pán)和鼠標那樣輸入數據以及控制光標。因此一種有效的語(yǔ)音控制光標程序, 也就是可以定位在屏幕的任意位置, 并且可以模擬單擊、雙擊拖拽等各種鼠標動(dòng)作的語(yǔ)音控制程序, 對于實(shí)現語(yǔ)音控制電腦將是一個(gè)很有意義的工具。
本文利用微軟的Speech SDK 5.1 免費的語(yǔ)音識別引擎和模擬鼠標技術(shù), 用Delphi7.0 實(shí)現了一個(gè)語(yǔ)音控制鼠標應用程序, 可以實(shí)現語(yǔ)音控制鼠標移動(dòng)、停止、單擊等動(dòng)作達到控制屏幕光標的作用, 并對語(yǔ)音控制鼠標程序中的延遲問(wèn)題進(jìn)行了分析, 提出并實(shí)現了一種改進(jìn)方法。
2 基于語(yǔ)音識別的光標控制類(lèi)型
目前有兩種語(yǔ)音控制鼠標的模式: 一種是目標導向光標控制和方向導向光標控制[n].對于前者, 用戶(hù)需要用語(yǔ)音給出具體目標名稱(chēng)或者位置, 比如圖標、菜單, 或者屏幕區域名稱(chēng), 然后給出執行的命令如單擊等, 這種方式對于單個(gè)軟件還是有效的, 但是當目標增加的時(shí)候用戶(hù)需要記憶很多目標的名稱(chēng), 還可能出現同名稱(chēng)目標的情況, 因此工作中的錯誤率會(huì )增加。另一種方向導向光標控制又分為非連續控制和連續控制兩種, 對于非連續的情況用戶(hù)要同時(shí)說(shuō)明方向和距離, 如命令左8 厘米, 那么光標就向左移動(dòng)8厘米; 而對于連續的情況用戶(hù)先說(shuō)明方向如向左,光標就向左移動(dòng), 直到用戶(hù)再說(shuō)停止, 光標才停止運動(dòng)。
本文討論的聲控光標是屬于方向導向中的連續控制, 這種鼠標控制和日常的使用習慣比較一致, 用戶(hù)使用起來(lái)比較適應。
3 實(shí)現
本文語(yǔ)音控制光標程序的語(yǔ)音控制是采用微軟的Speech SDK 5.1 的語(yǔ)音識別引擎及其API 接口, 這是一個(gè)免費的開(kāi)發(fā)包, 并且可以用它開(kāi)發(fā)具有中文語(yǔ)音功能的軟件。語(yǔ)音識別引擎通??梢苑譃閮煞N工作方式, 一種就是命令控制(Command and Control) 方式, 這個(gè)方式下語(yǔ)音識別引擎可以識別簡(jiǎn)短的語(yǔ)音命令, 以便執行相應的程序; 另外一種是連續聽(tīng)寫(xiě)方式,這個(gè)模式下語(yǔ)音識別引擎要識別連續的語(yǔ)音, 這種功能實(shí)現起來(lái)比語(yǔ)音控制更復雜, 因為語(yǔ)音聽(tīng)寫(xiě)過(guò)程中需要對上下文以及相同相似發(fā)音的詞語(yǔ)進(jìn)行分析、作出判斷, 而在命令控制語(yǔ)音方式中不需要作上下文分析。本文采用的是命令控制方式, 因為實(shí)現語(yǔ)音控制鼠標只需要對有限的幾個(gè)簡(jiǎn)短的命令進(jìn)行識別, 如左、右、停等。圖1 是語(yǔ)音控制鼠標程序的結構圖。
圖1 語(yǔ)音控制鼠標程序結構
該應用程序主要包括兩個(gè)部分: 第一部分語(yǔ)音控制應用主程序部分, 主要調用語(yǔ)音識別引擎識別用戶(hù)的語(yǔ)音命令。
這部分程序主要完成幾件工作:
?、賹朕o書(shū)文法文件(XML 格式, 其中定義感興趣的語(yǔ)音命令) , 完成對語(yǔ)音識別引擎接口的初始化工作, 激活語(yǔ)音識別引擎;②接收語(yǔ)音識別引擎的識別結果, 根據識別結果調用相應的鼠標控制程序。
下面的語(yǔ)法文件中定義了方向命令和鼠標事件命令的語(yǔ)法規則:
GRAMMAR LANGID=804>
DEFINE>
ID NAME=RID_start VAL=1/>
ID NAME=PID_colour VAL=2/>
ID NAME=PID_colourvalue VAL=3/>
/DEFINE>
! - - Rule definiTIons - - >
RULE NAME=start ID=RID_start TOPLEVEL=ACTIVE>
RULEREF NAME=colour PROPNAME=colourPROPID=PID_colour />
/RULE>
RULE NAME=colour >
L PROPNAME=colourvalue PROPID=PID_
colourvalue>
P VAL=1>上/P>
P VAL=2>下/P>
P VAL=3>左/P>
p VAL=4>右/p>
p VAL=5>停止/p>
P VAL=6>單擊/P>
P VAL=7>雙擊/P>
p VAL=8>關(guān)閉/p>
/L>
/RULE>
/GRAMMAR>
在程序運行的時(shí)候, 一旦有上述語(yǔ)法文件中定義的命令被成功識別, 則在程序的onRecgnition 響應函數中可以查詢(xún)出識別的返回值是1~8 中的某個(gè)值, 根據不同的返回值就可以調用鼠標控制程序進(jìn)行鼠標的某個(gè)方向的移動(dòng)或者點(diǎn)擊等事件的模擬控制。
第二部分鼠標控制程序, 就是調用程序模擬控制鼠標移動(dòng)或單擊等各種鼠標事件。這一部分主要是利用Windows API 函數模擬鼠標事件實(shí)現對鼠標光標的控制。
評論