| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2153 人关注过本帖
标题:[求助]有关TTS编程
只看楼主 加入收藏
lqflyc
Rank: 1
等 级:新手上路
帖 子:29
专家分:0
注 册:2006-11-30
收藏
 问题点数:0 回复次数:2 
[求助]有关TTS编程
有谁知道怎么编一个语音识别程序吗?
就是能将指定英语以合成音读出来!
希望各位大仙能帮一下,最好给一个简单实例.
以前做过的例子里如果有这方面应用也可以.
本人在这里先谢过了
搜索更多相关主题的帖子: TTS 
2007-02-15 21:48
bygg
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:乖乖的心中
等 级:版主
威 望:241
帖 子:13555
专家分:3076
注 册:2006-10-23
收藏
得分:0 
在VB中使用文字朗读引擎(TTS)技术


现今市面上流行的一些英语学习软件,在广告词上经常说自己使用了国际顶尖的全程语音TTS技术,能进行整段英文的流利朗读,并能自由调节朗读的速度与频率等。那么,这个神奇的TTS究竟是什么东西呢?

  其实,TTS是微软出品的一套文字朗读引擎(Text-To-Speech Engine),这些英语软件就是调用它来进行英文朗读的。我们在英语学习软件的编程开发中也可使用TTS技术,下面笔者将利用Visual Basic 5.0来揭开TTS神秘的面纱。

  一、安装TTS引擎
  TTS引擎所需的Microsoft Text-to-Speech Engine与Microsoft Speech API软件都可到微软的站点去下载,也可以在“金山词霸2000”或“金山词霸.net”的安装光盘上找到(文件名为MSTTS.EXE与SPCHAPI.EXE)。安装了TTS引擎后,在Windows所在目录下会生成一个SPEECH目录,其中有一个Vtxtauto.tlb文件,在编程时我们需要调用它。

  二、在VB中引入Vtxtauto.tlb文件
  进入VB 5.0,执行选单命令“文件/新建工程/标准EXE”并确定,然后执行选单“工程”中的“引用”,单击“浏览”按钮到Windows目录下的SPEECH子目录,打开Vtxtauto.tlb文件,将“VoiceText 1.0 Type Library”添加到引用列表中,选中它并单击确定。将库Vtxtauto引入VB后,我们可以通过选单“视图”中的“对象浏览器”来了解它所封装的类,以及各类成员函数的属性的意义、使用格式等信息。一些主要的方法与属性意义,笔者在下面的源程序中将给出注释,在这里就不详细列出,请参见附图1。


  三、设置控件及属性
  在FORM1上添加三个Label控件、一个TextBox控件、一个HScrollBar控件和六个CommandButton控件。窗体及各控件的主要属性设置如下:

  FORM1:Caption=“英文朗读”

  LABEL1:Caption=“请输入英文文档”

  LABEL2:Caption=“朗读速度”

  LABEL3:Caption=“ ”

  (LABEL3标签用来显示朗读速度值)

  TEXT1:Text=“Please input english text”;ToolTiptext=“请输入或粘贴英文文档”; MultiLine=True;ScrollBars=3-Both

  HSCROLL1:名称=SpeedChange;Min=90;Max=300(Min与Max属性值分别用来限定可调节的语速的最小与最大值)

  COMMAND1:名称=read;Caption=“朗读”

  COMMAND2:名称=pause;Caption=“暂停”

  COMMAND3:名称=stop;Caption=“停止”

  COMMAND4:名称=prev;Caption=“上一句”

  COMMAND5:名称=next;Caption=“下一句”

  COMMAND6:名称=quit;Caption=“退出”

  四、编写代码
  下面我们就可以一步步地编写代码,具体代码如下:

  '在窗体装载时调用Register方法注册,括号内的两个参数是字符串

  Private Sub Form_Load()

  Call VTxtAuto.VTxtAuto.Register(Space(8), Space(8))

  '因为语速的默认值为170,故水平滚动条的初值也设为170

  SpeedChange.Value = 170

  End Sub

  '设置朗读速度调节代码,当水平滚动条的值Value发生变化时将其赋给控制语速的Speed属性

  Private Sub SpeedChange_Change()

  VTxtAuto.VTxtAuto.Speed=SpeedChange.Value

  Label3.Caption = SpeedChange.Value

  End Sub

  '设置“朗读”按钮代码

  Private Sub read_Click()

  '如果朗读出错,则转到出错处理标记模块ErrorHandler

  On Error GoTo ErrorHandler

  '调用方法Speak进行朗读,第一个参数是要朗读的文本,第二个参数是设置朗读风格

  Call VTxtAuto.VTxtAuto.speak(Trim(Text1.Text), vtxtsp_VERYHIGH + vtxtst_READING)

  Exit Sub

  ErrorHandler:

  MsgBox "只能朗读英文文档,不能朗读汉字字符!", , "出错信息"

  End Sub

  '设置“暂停”按钮代码

  Private Sub pause_Click()

  If VTxtAuto.VTxtAuto.IsSpeaking Then

  '如果属性IsSpeaking为真,则表示正在朗读,调用AudioPause方法暂停朗读

  Call VTxtAuto.VTxtAuto.AudioPause

  pause.Caption = "恢复"

  Else

  '如果已经处于暂停状态则调用AudioResume方法恢复朗读

  Call VTxtAuto.VTxtAuto.AudioResume

  pause.Caption = "暂停"

  End If

  End Sub

  '设置“停止”按钮代码,调用StopSpeaking方法停止当前朗读

  Private Sub stop_Click()

  Call VTxtAuto.VTxtAuto.StopSpeaking

  End Sub

  '设置“上一句”按钮代码,调用AudioRewind方法往后跳过一句

  Private Sub prev_Click()

   Call VTxtAuto.VTxtAuto.AudioRewind

  End Sub

  '设置“下一句”按钮代码,调用AudioFastForward方法向前跳过一句

  Private Sub next_Click()

   Call VTxtAuto.VTxtAuto.AudioFastForward

  End Sub

  '设置“退出”按钮代码

  Private Sub quit_Click()

   Unload Me

  End Sub

  本程序在中文Windows 95/98、VB 5.0环境下运行通过。运行时在文本编辑框中输入或粘贴英文文档,然后单击“朗读”按钮就可播放读音,运行界面如图2。


  五、程序改进思路
  本文对在VB编程中使用TTS技术只是起个抛砖引玉的作用,熟悉VB编程的电脑爱好者来可以对本程序作一些改进,例如增加对声卡和TTS引擎是否安装的检测、增加从文本文件或数据库中读取文档的功能、增加让用户选择朗读的优先级和发声音量调节等功能。这些功能实现起来较为复杂,感兴趣的读者可进行深入研究。


飘过~~
2007-02-16 14:30
lqflyc
Rank: 1
等 级:新手上路
帖 子:29
专家分:0
注 册:2006-11-30
收藏
得分:0 

我已经找到相关资料了,现在发给大家作参考!希望对大家有用!
在.net中,对英文语音有较好的支持,但是对中文语音的支持还没有加入进来,我们要想实现中文发音或中文语音识别,必需先安装微软的Speech Application SDK(SASDK),它的最新版本是 SAPI 5.1 他能够识别中、日、英三种语言,你可以在这里下载:http://www.microsoft.com/speech/download/sdk51/,需要安装这两个文件Speech SDK 5.1和5.1 Language Pack,其中5.1 Language Pack可以选择安装支持的语言。

安装好以后,我们就可以开始进行语音程序的开发了,当然,在这之前我们需要把SAPI.dll通过如下图所示添加到引用中

下面我们设计一个能够朗读中英文混合语言的类:

我们将用单例模式实现该类,类的代码如下,我们将详细解释:

public class Speach

{

private static Speach _Instance = null ;

private SpeechLib.SpVoiceClass voice =null;

private Speach()

{

BuildSpeach() ;

}

public static Speach instance()

{

if (_Instance == null)

_Instance = new Speach() ;

return _Instance ;

}

private void SetChinaVoice()

{

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

}

private void SetEnglishVoice()

{

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

}

private void SpeakChina(string strSpeak)

{

SetChinaVoice() ;

Speak(strSpeak) ;

}

private void SpeakEnglishi(string strSpeak)

{

SetEnglishVoice() ;

Speak(strSpeak) ;

}

public void AnalyseSpeak(string strSpeak)

{

int iCbeg = 0 ;

int iEbeg = 0 ;

bool IsChina = true ;

for(int i=0;i<strSpeak.Length;i++)

{

char chr = strSpeak[i] ;

if (IsChina)

{

if (chr<=122&&chr>=65)

{

int iLen = i - iCbeg ;

string strValue = strSpeak.Substring(iCbeg,iLen) ;

SpeakChina(strValue) ;

iEbeg = i ;

IsChina = false ;

}

}

else

{

if (chr>122||chr<65)

{

int iLen = i - iEbeg ;

string strValue = strSpeak.Substring(iEbeg,iLen) ;

this.SpeakEnglishi(strValue) ;

iCbeg = i ;

IsChina = true ;

}

}

}//end for

if (IsChina)

{

int iLen = strSpeak.Length - iCbeg ;

string strValue = strSpeak.Substring(iCbeg,iLen) ;

SpeakChina(strValue) ;

}

else

{

int iLen = strSpeak.Length - iEbeg ;

string strValue = strSpeak.Substring(iEbeg,iLen) ;

SpeakEnglishi(strValue) ;

}

}

private void BuildSpeach()

{

if (voice == null)

voice = new SpVoiceClass() ;

}

public int Volume

{

get

{

return voice.Volume ;

}

set

{

voice.SetVolume((ushort)(value)) ;

}

}

public int Rate

{

get

{

return voice.Rate ;

}

set

{

voice.SetRate(value) ;

}

}

private void Speak(string strSpeack)

{

try

{

voice.Speak(strSpeack,SpeechVoiceSpeakFlags.SVSFlagsAsync) ;

}

catch(Exception err)

{

throw(new Exception("发生一个错误:"+err.Message)) ;

}

}

public void Stop()

{

voice.Speak(string.Empty,SpeechLib.SpeechVoiceSpeakFlags.SVSFPurgeBeforeSpeak) ;

}

public void Pause()

{

voice.Pause() ;

}

public void Continue()

{

voice.Resume() ;

}

}//end class



在 private SpeechLib.SpVoiceClass voice =null;这里,我们定义个一个用来发音的类,并且在第一次调用该类时,对它用BuildSpeach方法进行了初始化。

我们还定义了两个属性Volume和Rate,能够设置音量和语速。

我们知道,SpVoiceClass 有一个Speak方法,我们发音主要就是给他传递一个字符串,它负责读出该字符串,如下所示。

private void Speak(string strSpeack)

{

try

{

voice.Speak(strSpeack,SpeechVoiceSpeakFlags.SVSFlagsAsync) ;

}

catch(Exception err)

{

throw(new Exception("发生一个错误:"+err.Message)) ;

}

}

其中SpeechVoiceSpeakFlags.SVSFlagsAsync表示异步发音。


2007-02-17 19:03
快速回复:[求助]有关TTS编程
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015377 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved