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

--------------------------------------------------------------------------------

目录:
1.  SAPI.51  SDK浅析以及安装
2.  导入COM对象到.Net
3.  用C#开发中文TTS应用程序示例
4.  结论
5.  参考文献

--------------------------------------------------------------------------------

1.  sapi.51  sdk浅析以及安装
SAPI  SDK是微软公司免费提供的语音应用开发工具包,这个SDK中包含了语音应用设计接口(SAPI)、微软的连续语音识别引擎(MCSR)以及微软的语音合成(TTS)引擎等等。目前的5.1版本一共可以支持3种语言的识别  (英语,汉语和日语)以及2种语言的合成(英语和汉语)。SAPI中还包括对于低层控制和高度适应性的直接语音管理、训练向导、事件、语法编译、资源、语音识别(SR)管理以及TTS管理等强大的设计接口。其结构如图(1):
screen.width-333)  {this.width=screen.width-333;this.title='open  new  window';}"   οnmοuseοver="if(this.title)  {this.style.cursor='hand';}" ;  οnclick="if(this.title)  {window.open('http://www.microsoft.com/china/community/images/TechArticleImages/Cnspeech1.jpg');}">
图(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。
screen.width-333)  {this.width=screen.width-333;this.title='open  new  window';}"   οnmοuseοver="if(this.title)  {this.style.cursor='hand';}" ;  οnclick="if(this.title)  {window.open('http://www.microsoft.com/china/community/images/TechArticleImages/Cnspeech2.jpg');}" Cnspeech2.jpg?  border="0">
图(2)
打开Form1.cs代码文件,在代码开头添加名字空间(注意大小写)。
using  DotNetSpeech;
这样就实现了SAPI  SDK的导入,下面我们就可以开始编写应用代码了。本示例演示如何把文本通过喇叭朗读出来以及把文本转化成语音信号(Wave声音文件),程序界面如图(3):
screen.width-333)  {this.width=screen.width-333;this.title='open  new  window';}"   οnmοuseοver="if(this.title)  {this.style.cursor='hand';}" ;  οnclick="if(this.title)  {window.open('http://www.microsoft.com/china/community/images/TechArticleImages/Cnspeech3.jpg');}" Cnspeech3.jpg?  border="0">
//朗读
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)
screen.width-333)  {this.width=screen.width-333;this.title='open  new  window';}"   οnmοuseοver="if(this.title)  {this.style.cursor='hand';}" ;  οnclick="if(this.title)  {window.open('http://www.microsoft.com/china/community/images/TechArticleImages/Cnspeech4.jpg');}" Cnspeech4.jpg?  border="0">
在"文字-语音转换"的"语音选择"组合框中选择简体中文(Microsoft  Simplified  Chinese)。这样就可以合成汉语文字了。
回到VS.Net,F5编译运行刚才的应用程序,在文本框里输入汉字,戴上耳机,点击"朗读"按钮,开始体验新一代的智能人机界面吧,呵呵:)

--------------------------------------------------------------------------------

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

转载于:https://www.cnblogs.com/IWEB/archive/2007/01/30/635105.html

.Net平台下开发中文语音应用程序相关推荐

  1. python培训班-Python培训机构_高品质Python线下开发培训班推荐-黑马程序员

    Python编程基础基础班1 课时:15天技术点:97项测验:2次学习方式:线下面授 学习目标 1.掌握Python开发环境基本配置|2.掌握运算符.表达式.流程控制语句.数组等的使用|3.掌握字符串 ...

  2. Android 入门开发指南之三 -- 在其他平台下开发

    使用其它的集成开发环境和工具开发Android应用程序 推荐使用开发Android应用程序的开发环境是Eclipse+Android插件,该插件提供集成到Eclipse中的编辑,创建和调试功能.然而, ...

  3. linux 开发设计软件,在Linux平台下开发和设计聊天软件

    在网络无所不在的今天,在Internet上,有ICQ.MSN.Gtalk.OICQ等网络聊天软件,极大程度上方便了处于在世界各地的友人之间的相互联系,也使世界好像一下子缩小了,不管你在哪里,只要你上了 ...

  4. qt下开发mqtt的访问程序

    1.要下载mqtt模块 下载地址:https://github.com/emqx/qmqtt,注意要下载qmqtt-master版本的,不要下载qtmqtt-dev 下载符合你的qt版本,否则要接近的 ...

  5. TQ2440 学习笔记—— 1、Windows平台下开发工具安装与环境建立

    板子:广州天嵌公司的TQ2440,处理器为三星的S3C2440 1.开发工具的安装与环境建立 系统:win7  64位 SecureCRT软件:该软件可以代替Windows中的超级终端,是个非常好的串 ...

  6. 嵌入式Linux下开发中文输入法

    介绍 近期由于项目需求:设备端需要中文输入而手头又没有现成可用的中文输入法,因此就想办法看看能否捣鼓一个出来.当然,开始是没有任何信心的,也深知输入法别看他很小的一个东西,但内部涉及内容还是非常多的, ...

  7. VS code下开发单片机或者STM32程序

    一直想着编写单片机和32代码能不能换IDE,奈何关注了很久都没有发现一个比较好的.今天突然发现VS code竟然出了一个Keil Assistant的插件,虽说不能完全取代Keil,但是也足够方便与强 ...

  8. android 语音播报(通过手说tts 实现中文语音播报)

    手说TTS介绍: 关于手说tts中文语音包的详细资料可以查看官网 http://shoushuo.com/index.html 手说TTS,是Android平台下的中文语音引擎,提供了中文文本到语音的 ...

  9. android 语音播报中文,android 语音播报(通过手说tts 实现中文语音播报)

    手说TTS介绍: 手说TTS,是Android平台下的中文语音引擎,提供了中文文本到语音的转换. 使用手说TTS进行中文文本的朗读,包括中文简繁体.阿拉伯数字.英文字母及一些符号的混读.并且处理了中文 ...

最新文章

  1. 前途无量的MEMS传感器
  2. 学习ASP.NET Core Razor 编程系列九——增加查询功能
  3. 没有4G时代,有的只是后3G时代
  4. 小明爱跑步-扩展-多个对象属性之间互不干扰
  5. SIGIR2020 | 基于GCN的鲁棒推荐系统研究
  6. 485通讯的校验和_三菱FX3U与变频器通讯程序如何编写
  7. 使用 ngrok 进行内网穿透
  8. 加泰罗尼亚理工大学 计算机 排名,加泰罗尼亚理工大学排名
  9. 用HTML加css做成的新年特效,使用css3和html给网站添加上春节灯笼特效的源码分享...
  10. CentOS 8 更新/etc/yum.repos.d
  11. 学习vue3组件事件时,思维发散(溜号)的感悟
  12. Android应用性能优化最佳实践.2.3 布局优化
  13. 干掉Vivado幺蛾子(2)-- 快速替换debug probes
  14. 全球与中国2-碘吡啶市场深度研究分析报告
  15. 学计算机买笔记本是i5 i7,对我们普通人买电脑来说,i7和i5、i3有多大区别,玩游戏选哪款好?!...
  16. 多媒体个人计算机软件系统由,多媒体计算机软件系统由什么组成
  17. PHP实现微信公众平台开发---提升篇(上传素材并回复)
  18. 多相全程水处理器原理图
  19. BLS12-381 pairing-friendly 曲线
  20. SAP 物料主数据BP主数据同步第三方系统

热门文章

  1. RC4 调用Java库加解密
  2. 【外汇天眼】美国CFTC官方发布:外汇交易前你应该知道的八件事
  3. C++:实现量化cliquet option棘轮期权测试实例
  4. 给我未来的孩子--(转载)
  5. 经典管理故事:兔子与胡萝卜
  6. 明翰英语教学系列之数词篇V0.2(持续更新)
  7. Mosh Python教程练习题 Part 2
  8. 7月火影忍者服务器维护,火影忍者OL7月23日区服停机更新公告介绍
  9. glut绘制正余弦曲线
  10. 2023自助洗车店系统解决方案共享洗车无人洗车风口