Speech SDK中文语音识别技术在c#中的应用.doc

上传人:啊飒飒 文档编号:11385636 上传时间:2021-08-01 格式:DOC 页数:11 大小:142KB
返回 下载 相关 举报
Speech SDK中文语音识别技术在c#中的应用.doc_第1页
第1页 / 共11页
Speech SDK中文语音识别技术在c#中的应用.doc_第2页
第2页 / 共11页
Speech SDK中文语音识别技术在c#中的应用.doc_第3页
第3页 / 共11页
Speech SDK中文语音识别技术在c#中的应用.doc_第4页
第4页 / 共11页
Speech SDK中文语音识别技术在c#中的应用.doc_第5页
第5页 / 共11页
点击查看更多>>
资源描述

《Speech SDK中文语音识别技术在c#中的应用.doc》由会员分享,可在线阅读,更多相关《Speech SDK中文语音识别技术在c#中的应用.doc(11页珍藏版)》请在三一文库上搜索。

1、.Net平台下开发中文语音应用程序摘要:语音是人类最自然的交互方式,也是现阶段软件用户界面发展的最高目标。微软公司一直积极推动语音技术的发展,并且公布了语音开发平台Speech SDK帮助开发人员实现语音应用。随着.net技术深入人心,越来越多的程序员开始转到.net平台上进行开发。然而,在新发布的.net speech SDK里面并没有对中文语音进行支持,目前支持中文的Speech SDK最高版本为Windows平台下的SAPI 5.1(),本文介绍如何在.net平台下利用SAPI5.1开发中文语音应用程序。目录:1. SAPI.51 SDK浅析以及安装2. 导入COM对象到.Net3. 用

2、C#开发中文TTS应用程序示例4. 结论5. 参考文献1 SAPI.51 SDK浅析以及安装SAPI SDK是微软公司免费提供的语音应用开发工具包,这个SDK中包含了语音应用设计接口(SAPI)、微软的连续语音识别引擎(MCSR)以及微软的语音合成(TTS)引擎等等。目前的5.1版本一共可以支持3种语言的识别 (英语,汉语和日语)以及2种语言的合成(英语和汉语)。SAPI中还包括对于低层控制和高度适应性的直接语音管理、训练向导、事件、语法编译、资源、语音识别(SR)管理以及TTS管理等强大的设计接口。其结构如图(1):图(1)语音引擎则通过DDI层(设备驱动接口)和SAPI(SpeechAPI

3、)进行交互,应用程序通过API层和SAPI通信。通过使用这些API,用户可以快速开发在语音识别或语音合成方面应用程序。SAPI5.1 SDK可以从微软网站下载:http:/ 需要安装程序的有Speech SDK 5.1(68M)和5.1 Language Pack (81.5M)。2 导入COM对象到.NetSAPI5.1的基于Windows平台的,通过COM接口进行调用。在.Net平台下要应用SAPI5.1,我们可以利用.Net Framework自带的强大工具TlbImp.exe来把SAPI SDK的COM对象导入到.Net中。TlbImp.exe产生一个管制的包装类,管理客户端可以使用它

4、。包装类管理实际的COM对象的参考数。当包装类当作收集的垃圾时,包装类释放掉它包装的COM对象。当然,你也可以在VS.NET环境中通过从项目参考对话框选择COM对象,实现COM对象的导入,这个过程也是通过TlbImp.exe来完成的。下面演示如何导入SAPI的COM对象:D:Program FilesCommon FilesMicrosoft SharedSpeechTlbimp sapi.dll /out: DotNetSpeech.dll在安转SDK以后,可以在D:Program FilesCommon FilesMicrosoft SharedSpeech目录下面找到SAPI.dll,这

5、里面定义了SAPI的COM对象,用Tlbimp.exe工具将该dll转换成.net平台下的Assembly-DotNetSpeech.dll,转换的过程会提示不少的警告(warning),但这部影响我们的开发,可以忽略。最后,我们可以用ildasm查看DotnetSpeech.dll里面的对象。3 用C#开发中文TTS应用程序示例下面通过一个实例来介绍如何利用C# 进行开发语音应用程序,开发环境为:操作系统: Windows 2000 中文版+ SP3.Net Framework: 1.0.3705(英文版)Visual Studio.Net 7.0.9466(英文版)首先,新建一个C#的Wi

6、ndows Application工程SpeechApp,在开发环境的右边的解决方案管理器(Solution Explorer)中,添加DotNetSpeech对象库。右键点击Reference(参考),选择Add Reference(添加参考),在弹出的文件选择对话框中找到刚才生成的DotNetSpeech.dll。图(2)打开Form1.cs代码文件,在代码开头添加名字空间(注意大小写)。using DotNetSpeech;这样就实现了SAPI SDK的导入,下面我们就可以开始编写应用代码了。本示例演示如何把文本通过喇叭朗读出来以及把文本转化成语音信号(Wave声音文件),程序界面如图(

7、3):/朗读private void buttonSynthesis_Click(object sender, System.EventArgs e)trySpeechVoiceSpeakFlags SpFlags = SpeechVoiceSpeakFlags.SVSFlagsAsync;SpVoice Voice = new SpVoice();Voice.Speak(this.textBoxText.Text, SpFlags);catch(Exception er)MessageBox.Show(An Error Occured!,SpeechApp, MessageBoxButton

8、s.OK, MessageBoxIcon.Error);/生成声音文件(Wav)private void buttonTTStoWave_Click(object sender, System.EventArgs e)trySpeechVoiceSpeakFlags SpFlags = SpeechVoiceSpeakFlags.SVSFlagsAsync;SpVoice Voice = new SpVoice();SaveFileDialog sfd = new SaveFileDialog();sfd.Filter = All files (*.*)|*.*|wav files (*.wa

9、v)|*.wav;sfd.Title = Save to a wave file;sfd.FilterIndex = 2;sfd.RestoreDirectory = true;if (sfd.ShowDialog()= DialogResult.OK) SpeechStreamFileMode SpFileMode = SpeechStreamFileMode.SSFMCreateForWrite;SpFileStream SpFileStream = new SpFileStream();SpFileStream.Open(sfd.FileName, SpFileMode, false);

10、Voice.AudioOutputStream = SpFileStream;Voice.Speak(txtSpeakText.Text, SpFlags);Voice.WaitUntilDone(Timeout.Infinite); SpFileStream.Close();catch(Exception er)MessageBox.Show(An Error Occured!,SpeechApp, MessageBoxButtons.OK, MessageBoxIcon.Error);接下来,还要去控制面板配置Speech SDK引擎当前所处理语言。打开控制面板,打开语音配置项目,可以看到

11、在这里我们可以指定当前可以对何种语言进行识别或者合成,还可以配置相关的硬件设备以及控制语速。(如图4)在文字-语音转换的语音选择组合框中选择简体中文(Microsoft Simplified Chinese)。这样就可以合成汉语文字了。回到VS.Net,F5编译运行刚才的应用程序,在文本框里输入汉字,戴上耳机,点击朗读按钮,开始体验新一代的智能人机界面吧,呵呵:).Net平台下开发英文语音应用程序 程序演示:点击下载源文件:点击下载1、先安装金山词霸然后会在系统目录Win2000是WINNT目录下Speech中找到vtxtauto.tlb文件2、导入COM对象到.Net我们可以利用.Net F

12、ramework自带的强大工具TlbImp.exe来把SAPI SDK的COM对象导入到.Net中。TlbImp.exe产生一个管制的包装类,管理客户端可以使用它。包装类管理实际的COM对象的参考数。当包装类当作收集的垃圾时,包装类释放掉它包装的COM对象。当然,你也可以在VS.NET环境中通过从项目参考对话框选择COM对象,实现COM对象的导入,这个过程也是通过TlbImp.exe来完成的。C:WINNTSpeechTlbimp vtxtauto.tlb /namespace:DotNetSpeech_E /out: DotNetSpeech_E.dll3 用C#开发英文TTS应用程序示例下

13、面通过一个实例来介绍如何利用C# 进行开发英文语音应用程序,开发环境为:Win2K+SP4+.Net Framework v1.1+Microsoft Visual Studio .NET 2003首先,新建一个C#的Windows Application工程SpeechAppen,在开发环境的右边的解决方案管理器(Solution Explorer)中,添加DotNetSpeech_E对象库。右键点击Reference(参考),选择Add Reference(添加参考),在弹出的文件选择对话框中找到刚才生成的DotNetSpeech_E.dll。下面我们就可以开始编写应用代码了。本示例演示如

14、何把英文文本通过喇叭朗读出来程序界面如图:/ / 朗读/ / / private void ButtonSynthesis_Click(object sender, System.EventArgs e)tryif(this.textBox1.Text.Trim()!=)DotNetSpeech_E.IVTxtAuto IVTA = new DotNetSpeech_E.VTxtAutoClass();IVTA.Register( , );IVTA.Speak(this.textBox1.Text,0);catch(System.Exception ec)MessageBox.Show(ec.ToString(),SpeechApp,MessageBoxButtons.OK,System.Windows.Forms.MessageBoxIcon.Error);4、结论.net环境更使这种开发方便快捷。赶快去测试,让你的应用程序绘声绘色,体现Nature UI,Lets GO!更多免费资源下载:http:/

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 科普知识


经营许可证编号:宁ICP备18001539号-1