人人做人人澡人人爽欧美,国产主播一区二区,久久久精品五月天,羞羞视频在线观看免费

當(dāng)前位置:蘿卜系統(tǒng)下載站 > 技術(shù)開發(fā)教程 > 詳細(xì)頁面

中英文語音合成與中文語音識別技術(shù)在c#中的應(yīng)用(二)

中英文語音合成與中文語音識別技術(shù)在c#中的應(yīng)用(二)

更新時間:2022-07-12 文章作者:未知 信息來源:網(wǎng)絡(luò) 閱讀次數(shù):

但是,這個方法本身并不知道你給的字符串是什么語言,所以需要我們它這個字符串用什么語言讀出。SpVoiceClass 類的Voice 屬性就是用來設(shè)置語種的,我們可以通過SpVoiceClass 的GetVoices方法得到所有的語種列表,然后在根據(jù)參數(shù)選擇相應(yīng)的語種,比如設(shè)置語種為漢語如下所示:

private void SetChinaVoice()

{

voice.Voice = voice.GetVoices(string.Empty,string.Empty).Item(0) ;

}

0表示是漢用,1234都表示英語,就是口音不同。

這樣,我們就設(shè)置了語種,如果結(jié)合發(fā)音方法,我們就可以設(shè)計出一個只發(fā)漢語語音的方法

private void SpeakChina(string strSpeak)

{

SetChinaVoice() ;

Speak(strSpeak) ;

}

只發(fā)英語語音的方法也是類似的,上面程序里有。

對于一段中英文混合的語言,我們讓程序讀出混合語音的方法就是:編程把這段語言的中英文分開,對于中文調(diào)用SpeakChina方法,英文調(diào)用SpeakEnglishi方法;至于怎樣判斷一個字符是英文還是中文,我采用的是判斷asc碼的方法,具體的類方法是通過AnalyseSpeak實現(xiàn)的。

這樣,對于一段中英文混合文字,我們只需把它作為參數(shù)傳遞給AnalyseSpeak就可以了,他能夠完成中英文的混合發(fā)音。

當(dāng)然,對于發(fā)音的暫定、繼續(xù)、停止等操作,上面也給出了簡單的方法調(diào)用,很容易明白。



下面簡單介紹一下中文語音識別的方法:

先把該語音識別的類源代碼貼在下面,然后再做說明:

public class SpRecognition

{

private static SpRecognition _Instance = null ;

private SpeechLib.ISpeechRecoGrammar isrg ;

private SpeechLib.SpSharedRecoContextClass ssrContex =null;

private System.Windows.Forms.Control cDisplay ;

private SpRecognition()

{

ssrContex = new SpSharedRecoContextClass() ;

isrg = ssrContex.CreateGrammar(1) ;

SpeechLib._ISpeechRecoContextEvents_RecognitionEventHandler recHandle =

new _ISpeechRecoContextEvents_RecognitionEventHandler(ContexRecognition) ;

ssrContex.Recognition += recHandle ;

}

public void BeginRec(Control tbResult)

{

isrg.DictationSetState(SpeechRuleState.SGDSActive) ;

cDisplay = tbResult ;

}

public static SpRecognition instance()

{

if (_Instance == null)

_Instance = new SpRecognition() ;

return _Instance ;

}

public void CloseRec()

{

isrg.DictationSetState(SpeechRuleState.SGDSInactive) ;

}

private void ContexRecognition(int iIndex,object obj,SpeechLib.SpeechRecognitionType type,SpeechLib.ISpeechRecoResult result)

{

cDisplay.Text += result.PhraseInfo.GetText(0,-1,true) ;

}



}



我們定義了ssrContex 和isrg為語音識別的上下文和語法,通過設(shè)置isrg的DictationSetState方法,我們可以開始或結(jié)束識別,在上面的程序中是BeginRec和CloseRec方法。cDisplay 是我們用來輸出識別結(jié)果的地方,為了能夠在大部分控件上都可以顯示結(jié)果,我用了一個Control 類來定義它。當(dāng)然,每次語音識別后都會觸發(fā)ISpeechRecoContextEvents_RecognitionEventHandler 事件,我們定義了一個這樣的方法ContexRecognition來響應(yīng)事件,并且在這個方法里輸出識別結(jié)果。



這樣,中文語音處理的一些最基本的問題就有了一個簡單的解決方法,當(dāng)然,這種方法還有很多不完善的地方,希望大家多提出批評意見,共同提高。

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統(tǒng)下載排行

網(wǎng)站地圖xml | 網(wǎng)站地圖html
主站蜘蛛池模板: 广宗县| 平利县| 安溪县| 三门峡市| 锡林浩特市| 石楼县| 宝丰县| 荥经县| 沅江市| 马关县| 眉山市| 和平县| 扬中市| 永修县| 都安| 阿鲁科尔沁旗| 务川| 双流县| 民权县| 久治县| 固始县| 定边县| 巴楚县| 延吉市| 南投县| 葫芦岛市| 瑞丽市| 平定县| 池州市| 道孚县| 南投县| 当雄县| 阳江市| 岳阳县| 临沭县| 南漳县| 武平县| 康平县| 阿荣旗| 比如县| 福州市|