.Net平台下开发中文语音应用程序

原创 2004年08月08日 14:56:00

陈本峰  改动:Lion http://www.microsoft.com

程序下载:点击下载
源文件:点击下载

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


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


图(1)
语音引擎则通过DDI层(设备驱动接口)和SAPI(SpeechAPI)进行交互,应用程序通过API层和SAPI通信。通过使用这些API,用户可以快速开发在语音识别或语音合成方面应用程序。
SAPI5.1 SDK可以从微软网站下载:http://www.microsoft.com/speech/download/sdk51/ 需要安装程序的有Speech SDK 5.1(68M)和5.1 Language Pack (81.5M)。


2. 导入COM对象到.Net
SAPI5.1的基于Windows平台的,通过COM接口进行调用。在.Net平台下要应用SAPI5.1,我们可以利用.Net Framework自带的强大工具TlbImp.exe来把SAPI SDK的COM对象导入到.Net中。TlbImp.exe产生一个管制的包装类,管理客户端可以使用它。包装类管理实际的COM对象的参考数。当包装类当作收集的垃圾时,包装类释放掉它包装的COM对象。当然,你也可以在VS.NET环境中通过从项目参考对话框选择COM对象,实现COM对象的导入,这个过程也是通过TlbImp.exe来完成的。
下面演示如何导入SAPI的COM对象:
D:/Program Files/Common Files/Microsoft Shared/Speech>Tlbimp sapi.dll /out: DotNetSpeech.dll

在安转SDK以后,可以在D:/Program Files/Common Files/Microsoft Shared/Speech/目录下面找到SAPI.dll,这里面定义了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#的Windows Application工程SpeechApp,在开发环境的右边的解决方案管理器(Solution Explorer)中,添加DotNetSpeech对象库。右键点击"Reference"(参考),选择"Add Reference"(添加参考),在弹出的文件选择对话框中找到刚才生成的DotNetSpeech.dll。

打开Form1.cs代码文件,在代码开头添加名字空间(注意大小写)。
using DotNetSpeech;
这样就实现了SAPI SDK的导入,下面我们就可以开始编写应用代码了。本示例演示如何把文本通过喇叭朗读出来以及把文本转化成语音信号(Wave声音文件),程序界面如图(3):

//朗读
private void buttonSynthesis_Click(object sender, System.EventArgs e)
{
 try
{
  SpeechVoiceSpeakFlags SpFlags = SpeechVoiceSpeakFlags.SVSFlagsAsync;
  SpVoice Voice = new SpVoice(); 
  Voice.Speak(this.textBoxText.Text, SpFlags);
 }
 catch(Exception er)
 {
MessageBox.Show("An Error Occured!","SpeechApp", MessageBoxButtons.OK, MessageBoxIcon.Error);
 }
}
//生成声音文件(Wav)
private void buttonTTStoWave_Click(object sender, System.EventArgs e)
{
 try
{
  SpeechVoiceSpeakFlags SpFlags = SpeechVoiceSpeakFlags.SVSFlagsAsync;
  SpVoice Voice = new SpVoice(); 
  SaveFileDialog sfd = new SaveFileDialog();
  sfd.Filter = "All files (*.*)|*.*|wav files (*.wav)|*.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);
   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引擎当前所处理语言。打开"控制面板",打开"语音"配置项目,可以看到在这里我们可以指定当前可以对何种语言进行识别或者合成,还可以配置相关的硬件设备以及控制语速。(如图4)

在"文字-语音转换"的"语音选择"组合框中选择简体中文(Microsoft Simplified Chinese)。这样就可以合成汉语文字了。
回到VS.Net,F5编译运行刚才的应用程序,在文本框里输入汉字,戴上耳机,点击"朗读"按钮,开始体验新一代的智能人机界面吧,呵呵:)

 

4. 结论
微软为语音人机界面提供了强大的平台,.net环境更使这种开发方便快捷。赶快去下载SAPI5.1 SDK,让你的应用程序"绘声绘色",体现Nature UI,Let’s GO!!!

5. 参考文献
[1] Speech SDK自带的说明文档(SAPI.chm)
[2] MSDN (msdn.microsoft.com)

百度语音识别开放平台SDK使用方法

本文介绍了百度语音识别sdk简单的集成方法
  • zpf8861
  • zpf8861
  • 2014年06月12日 11:25
  • 13099

关于桌面软件的开发语言和开发框架的思考

在未来的桌面软件的开发,我会这样考虑:windows系统下,C#编写界面,C#编写对效率要求不高的算法,C/C++编写对效率要求高的算法。需要跨平台时,如果C#现在的跨平台做得足够好,即mono项目足...
  • clever101
  • clever101
  • 2015年09月25日 23:44
  • 15529

基于科大讯飞语音云windows平台开发

转载自:http://blog.csdn.net/liucheng5037/article/details/31773841?utm_source=tuicool&utm_medium=referra...
  • u012377333
  • u012377333
  • 2016年09月05日 19:36
  • 5443

.Net平台下开发中文语音应用程序

摘要: 语音是人类最自然的交互方式,也是现阶段软件用户界面发展的最高目标。微软公司一直积极推动语音技术的发展,并且公布了语音开发平台Speech SDK帮助开发人员实现语音应用。 随着.net技术...
  • robake
  • robake
  • 2012年02月29日 09:45
  • 437

.Net平台下开发中文语音应用程序

【转载】:http://www.microsoft.com/china/community/program/originalarticles/techdoc/Cnspeech.mspx   摘要:...
  • rongrjianxin
  • rongrjianxin
  • 2014年02月12日 22:30
  • 463

C#.Net平台下开发中文语音应用程序

  • 2008年07月26日 16:16
  • 95KB
  • 下载

Net平台下开发中文语音应用程序

  • 2010年07月12日 22:29
  • 115KB
  • 下载

使用VS Code 开发.NET Core 应用程序 部署到Linux 跨平台

来源:LineZero链接:http://www.cnblogs.com/linezero/p/5460759.html使用VS Code 开发.NET Core 应用程序 部署到Linux 跨平台。...
  • gangzhucoll
  • gangzhucoll
  • 2016年08月10日 16:36
  • 2901

WinCE平台搭建--基于数据库的.NET应用程序开发(wince6.0+vs2008+sqlce)

最近在开发在WinCE上的基于数据库的.NET应用程序,总结下入门经验,首先讲下平台的搭建,然后简要的解释下可能遇到的问题。   一、平台搭建的前提条件 1、电脑上已经安装好了 SQL Serv...
  • whutcomputer
  • whutcomputer
  • 2011年10月21日 20:41
  • 3645

.net 语音应用程序

  • 2015年11月06日 16:58
  • 115KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:.Net平台下开发中文语音应用程序
举报原因:
原因补充:

(最多只允许输入30个字)