动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ ASP.NET技巧 ]的信息

本月文章推荐
.使用 ASP.NET Atlas PageNavigat.
.ASP.NET 2.0页面框架简要慨述.
.用post方法从网上抓取信息.
.DataGrid的多行提交.
.asp.net2.0如何加密数据库联接字.
.慎用url重写 .
.asp.net(vb.net)连接sql server .
..NET中Socket编程的简单示例.
.深度解析ASP.NET2.0中的Callback.
.用window.location.href实现刷新.
.Web.config详解+asp.net优化.
.DataGrid和DataList中CommandBut.
.权限树中Checkbox的操作[Asp.Net.
.ASP.NET程序中常用的三十三种代码.
.ASP.NET保持用户状态的九种选择(.
.充分利用ASP.NET的三种缓存提高站.
.在ASP.NET中跨页面实现多选.
.asp.net 操作xml.
.压力监测程序sqlserver和MYSQL版.
.一个读取扩展名为xml的资源文件的.

在ASP.NET程序中实现语音合成

发表日期:2006-3-2 |


  你可能已经注意到,如今语音合成越来越普遍。成百上午的电动玩具和小器具都能够以机器的声音向它们的主人讲话。不管它是一个讲话的婴儿玩偶,一个会谈话的计步器或是一新的自动电话系统,现在几乎每天都会有一种使用文本来发音的产品发行。

  文本-到-语音(TTS)技术,也称为语音合成,是把输入的文本转换成音频语音的过程。这种方式会优于预先录制好的文本-它必须对要说的内容提前了解。而使用TTS,却有可能加入动态的信息,该动态的信息可以来自于一个数据库;或是用户不断重复的话。

  一、 TTS试验

  如果你看到或听说过实际的TTS,那么你可能想下载一个免费版本的ReadPlease 2003。该产品能够读取Windows剪贴板中的文本。要使用它,你只需要简单地把一些文本粘贴到ReadPlease编辑器中(见图1)-并且假定你的PC扬声器打开了,那么你会听到文本的播放。当前,该产品仅能工作在所有的Windows桌面OS版本中,但是他们还计划发行针对Mac,Unix,Palm和Windows CE系统的版本。

  ReadPlease令人感兴趣的地方在于,你可以使用ReadPlease编辑器来试验你的TTS参数选择。例如,你可以通过上下移动如图1所示的Speed滑动块控件来调整发音速度。你还可以通过点击在小脸图标下方的箭头按钮来改变所用的语音。


图1.ReadPlease 2003应用程序:这个Windows应用程序可能读任何从剪贴板中粘贴到编辑字段中的文本。

  你需要什么呢?Visual Studio.NET 2003,微软语音应用程序SDK 1.1

  点击"Tools"菜单,然后选择"Options"允许你进一步用该TTS编辑器进行试验,例如,你可以调整在段落之间的语音引擎的暂停时间长度。升级到ReadPlease Plus版本将可以使你存取另外的一个发音编辑器选项,它让你指定怎样读一个特别的词。ReadPlease Plus还包括一个你可以停靠在你的Windows桌面顶部的任务条。因此,你可以快速地从任何基于文件的应用程序拖动文本到任务栏上并让它读给你听。

  缺省状态下,该ReadPlease应用程序使用内置的微软语音(Mark,Mike,Sam或Marilyn)。但是,你可以选择性地购买更高质量的AT&T Natural Voices,例如在AT&T Natural Voices Starter Pack中提供的语音。该Starter包包括8K版本的"Mike"和"Crystal",它们二者听起来都优于缺省的微软声音。

  作者注: 术语8K意味着,该抽样频率用于创建发生在每秒8000位的WAV文件。另外一种格式是16k,它可以产生一种更清晰和更为自然的听觉效果。基本上,样本率越高,声音质量好越。

  二、 微软语音应用程序开发包SDK 1.1

  在2004年,微软发行了 Microsoft Speech Server,还有一个免费的SDK允许你开发基于Web的运行于Speech Server上的语音程序。可以使用SDK来构建电话或只发声的应用程序-其中的计算机对用户的交互是使用电话来实现的。同时你还可以构建多模态应用程序,其中由用户选择使用语音还是传统型Web控件作为输入。

  微软TTS引擎通过把单词拆分成音素来合成文本。音素是人类语言的基本单位。它们代表一组"音",正是由它们构成单词的声音。然后由该TTS引擎分析提取的音素并且把它们转换成符号用来生成数字音频语音。

  你可以使用随同本文的可下载的示例应用程序(ExploringTextToSpeech.csproj)来试验微软TTS引擎可配置的方面。该多模态应用程序包含一个Web页面(见图2),你可以在其中输入一些文本。然后,可以点击一个按钮来以下面方式听取文本。

  作者注:在要被播放的文本无法提前知道的情况下,使用一TTS引擎是不可避免的;然而,你可以由录制音频来得到更好的音质。当音频质量是关键的时,你可以使用微软语音应用程序软件开发工具箱(SASDK)来录制音频。例如,你可能想使用录制的音频来提示用户信息。被记录的音频可以被分解成一系列的提示,它们在运行时刻再被连接起来。

  · Speak Text Normally-提供一种测试基准

  · Say as an Acronym-文本"ASP"被发作"A.S.P."

  · Say as Name-Mr.John Doe被发作"Mister John Doe"

  · Say As Date-在这种情况中,日期格式化为:月,日,年

  · Say as Web Address-在这种情况中,文本格式化为一个统一资源标识符(URI)

  · Say as Digits-作为文本输入的数字被发作一系列的位

  · High Pitch/Slow Rate-文本以高音调慢速发出。

  · Rate Fast/Volume Loud-文本以快速高音发出。

  · Low Pitch/Volume Soft-文本以低音调适中音量发出。


图2.示例应用程序-你可以使用这个程序来听一下以多种方式说出的文本。

  该多模态应用程序使用一提示控件来指定将被播放给用户的音频。该提示控件包含InlineContent属性——它可以包含一个或者是Content型或者是Value型的基本Speech控件。该Content控件指定一特定的包含存储的音频记录的提示文件。该Value控件指定一个HTML Web页面中的元素。该示例应用程序使用一Value控件——它参考一个名为txtText的输入元素(在图2中的"Type some text here:"域)。下面是描述了用于一个提示的标注的HTML:

<speech:prompt id="prmText" runat="server">
<InlineContent>
<speech:Value runat="server"
TargetElement="txtText"
TargetAttribute="value">
</speech:Value>
</InlineContent>
</speech:prompt>

  三、 语音合成标注语言

  该TTS引擎在怎样播放由属性InlineContent参考的文本时作出某些缺省的假设,但是开发者能通过使用语音合成标注语言(SSML)元素来控制该TTS引擎生成音频的方式。根据W3C协会的推荐,SSML是一基于XML的标注语言。表1列举出由SASDK所支持的SSML元素。

  表1.被支持的SSML元素:表中列出由SASDK所支持的SSML元素并且用于控制TTS引擎生成文本的方式。

SSML元素 描述
ssml:paragraph/ssml:sentence 用于把文本分解成语句或段落。
ssml:say-as 用于指定播放文本的方式。它能够接受若干不同的属性来指定文本的类型。
ssml:phoneme 用于控制一个单词的发音方式。
ssml:sub 用于指定一个替代单词或词组来代替指定的文本。
ssml:emphasis 用于提高放到一单词或词组中的重音。
ssml:break 用于在文本的某些单词间插入一些暂停。
ssml:prosody 用于控制音调,速率和音量。
ssml:audio 用于插入被录制的音频文件。
ssml:mark 用于在文本的某个位置插入一个标记。然后可以使用这个标记来表示一事件或触发一个行为。

  该示例应用程序说明了say-as和prosodySSML元素的使用。在该Default.aspx页面上的每个按钮都相应于一个提示控件。这些提示控件在InlineContent元素中包括一ssml:say-as或一个ssml:prosody元素。下面示例显示了针对这些元素之一的HTML标注:

<speech:prompt id="prmSayAsAcronym" runat="server">
<InlineContent>
<ssml:say-as type="acronym">
<speech:Value runat="server"
TargetElement="txtText"
TargetAttribute="value"></speech:Value>
</ssml:say-as>
</InlineContent>
</speech:prompt>

  当用户点击这些按钮之一,它执行如下所示的JavaScript:

function SayAsAcronym() {
 prmSayAsAcronym.Start();
}

  在上面的示例中,名为prmSayAsAcronym的提示包括了ssml:say-as元素,它指定任何包含在txtText输入元素中的文本都应该被以每个单词的第一个字母方式发出。因此,如果你输入"ASP"到文本元素中并且点击"Say As Acronym",那么该TTS引擎将读每个字母。

  为了用该示例应用程序进行试验,你可以输入一些文本片断,然后点击每一个按钮来看一下该TTS引擎是怎样解释文本的。我主张你改变元素值并且用每一个控件生成的方式进行试验。SASDK提供给开发者关于该TTS引擎怎样生成文本的良好控件,因此试验可能会导致出现一种更为自然的基于语音的应用程序。
上一篇:101个微软提供的Visual Studio 2005示例 人气:7706
下一篇:ASP.NET2.0 HiddenField控件 人气:6435
浏览全部ASP.NET的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-9-6 Movie34电影搜索引擎 v3.0
2008-9-6 wap2.0仿帝国建站喜用 v2.0
2008-9-6 免费人才招聘网 宽屏版 v3.01
2008-9-6 喜喔喔视频采集程序 v1.0 beta
2008-9-6 ASP客户管理系统
2008-9-6 主流驿站中秋祝福程序
2008-9-6 php实现msn协议的类
2008-9-5 Coppermine Photo Gallery v1.4.
2008-9-5 清松网络日记本 v2.4
2008-8-23 Mini WinMount V0.4
2008-8-23 Vista优化大师3.11正式版
2008-8-23 Wine 1.13
2008-8-23 KlipFolio 5.0 Build 5899-80
2008-8-23 Windows Sysinternals Desktops
2008-8-23 OneTap Movies1.2破解版
2008-8-23 AnnotaterPDF阅读1.1.503 破解版
2008-8-23 SoundMeter分贝测量仪 v1.0汉化破
2008-8-23 iDrum音乐节拍1.0破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | Html转换js | js/vbs加密 | md5加密 | 进制转换
实用工具:汉字翻译拼音 | 符号对照表 | 个税计算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号