COM组件使用speech:

public class Speach
{
private static Speach _Instance = null ;
private SpeechLib.SpVoiceClass voice =null; //SAPI5.1
private SpeechLib.SpVoice voice = null;//SAPI 5.4
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

使用.NET类库和系统API:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Speech.Synthesis;
using System.Speech;

namespace StudyBeta
{
    public class SRead
    {
        public SpeechSynthesizer synth; //语音合成对象
        public SRead()
        {
            synth = new SpeechSynthesizer();
        }
        public SRead(int m, int n)
        {
            //使用 synth 设置朗读音量 [范围 0 ~ 100]
            synth.Volume = m;
            //使用 synth 设置朗读频率 [范围 -10 ~ 10]
            synth.Rate = n;
        }
        public void SpeakChina(string ggg)
        {
            //SpVoice Voice = new SpVoice();
            synth.SelectVoice("Microsoft Lili");
            //Voice.Speak(ggg, SpFlags);
            synth.SpeakAsync(ggg);
            //String speechPeople = synth.Voice;
            //使用 synth 设置朗读音量 [范围 0 ~ 100]
            // synth.Volume = 80;
            //使用 synth 设置朗读频率 [范围 -10 ~ 10]
            //      synth.Rate = 0;
            //使用synth 合成 wav 音频文件:
            //synth.SetOutputToWaveFile(string path);
        }
        public void SpeakEnglish(string ggg)
        {
            //SpVoice Voice = new SpVoice();
            synth.SelectVoice("VW Julie");
            synth.Speak(ggg); //ggg为要合成的内容
        }
        public int m
        {
            get
            {
                return synth.Volume;
            }
            set
            {
                synth.Volume = value;
            }
        }
        public int n
        {
            get
            {
                return synth.Rate;
            }
            set
            {
                synth.Rate = value;
            }
        }
}

TTS朗读软件调用Microsoft Speech Platform

1.支持Microsoft Speech Platform的TTS朗读软件

介绍过的BalabolkaTextToWav都支持Microsoft Speech Platform,可以直接使用。

  • Balabolka和TextToWav都是32位程序,所以Microsoft Speech Platform Runtime需要安装32位的,无论系统是否是64位;
  • TextToWav官方说明是支持Microsoft Speech Platform 10,但测试Version 11也完美支持。

2.不支持Microsoft Speech Platform的TTS朗读软件

也就是早期只支持SAPI4和SAPI5的TTS朗读软件,比如DSpeech朗读女。这类软件就只能更改Microsoft Speech Platform语音库的注册信息了。

以Windows 7安装Microsoft Huihui为例

  1. 执行完整“Microsoft Speech Platform 11安装”步骤(Dspeech和朗读女也是32位);
  2. 64位Windows7打开注册表,找到

    HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Speech
    HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Speech Server

    分别导出(32为应该在HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\);

  3. 编辑Speech Server.reg
    • 将全部“Speech Server\v11.0”替换为“Speech”;
    • 将全部“Speech Server\\v11.0”替换为“Speech”。
  4. 依次导入Speech Server.reg和Speech.reg,中间提示错误信息不用理会。

这样在Dspeech和朗读女中已经可以正确显示和调用Microsoft Huihui朗读文本了。
同时,这样修改后,支持Microsoft Speech Platform的TTS朗读软件并不受影响。


以上两种方法取决于TTS朗读软件对Microsoft Speech Platform的支持情况,但系统的控制面板并不会显示有新的语音库可选,只能使用TTS朗读软件。
其他收费TTS朗读软件没做测试。
如果你使用的是Neospeech等高级语音库,没有必要用微软的,微软的只是一个简化版语音库,但是是完全免费。

http://blog.sina.com.cn/s/blog_5de73d0b01017go4.html

Speech两种使用方法的更多相关文章

  1. angular2系列教程(十)两种启动方法、两个路由服务、引用类型和单例模式的妙用

    今天我们要讲的是ng2的路由系统. 例子

  2. git两种合并方法 比较merge和rebase

    18:01 2015/11/18git两种合并方法 比较merge和rebase其实很简单,就是合并后每个commit提交的id记录的顺序而已注意:重要的是如果公司用了grrit,grrit不允许用m ...

  3. 两种Ajax方法

    两种Ajax方法 Ajax是一种用于快速创建动态网页的技术,他通过在后台与服务器进行少量的数据交换,可以实现网页的异步更新,不需要像传统网页那样重新加载页面也可以做到对网页的某部分作出更新,现在这项技 ...

  4. mysql in 的两种使用方法

    简述MySQL 的in 的两种使用方法: 他们各自是在 in keyword后跟一张表(记录集).以及在in后面加上字符串集. 先讲后面跟着一张表的. 首先阐述三张表的结构: s(sno,sname. ...

  5. C#中的两种debug方法

    这篇文章主要介绍了C#中的两种debug方法介绍,本文讲解了代码用 #if DEBUG 包裹.利用宏定义两种方法,需要的朋友可以参考下   第一种:需要把调试方法改成debug代码用 #if DEBU ...

  6. Service的两种启动方法

    刚才看到一个ppt,介绍service的两种启动方法以及两者之间的区别. startService 和 bindService startService被形容为我行我素,而bindService被形容 ...

  7. jQuery ajax调用后台aspx后台文件的两种常见方法(不是ashx)

    在asp.net webForm开发中,用Jquery ajax调用aspx页面的方法常用的有两种:下面我来简单介绍一下. [WebMethod] public static string SayHe ...

  8. android studio gradle 两种更新方法更新

    android studio gradle 两种更新方法更新 第一种.Android studio更新 第一步:在你所在项目文件夹下:你项目根目录gradlewrappergradle-wrapper ...

  9. iOS学习——UITableViewCell两种重用方法的区别

    今天在开发过程中用到了UITableView,在对cell进行设置的时候,我发现对UITableViewCell的重用设置的方法有如下两种,刚开始我也不太清楚这两种之间有什么区别.直到我在使用方法二进 ...

随机推荐

  1. Cacti的基本使用

    对于Cacti是通过snmpget来获取数据,使用 RRDtool绘画图形,用snmp服务获取数据,然后用rrdtool储存和更新数据,那么就可以简单理解为Cacti就是RRDTool的一个web图形 ...

  2. ue4 build configuration的解释

    ue4的build系统,继承并发展了3代的一如既往的复杂.. 一.每个configuration由两部份组成:[(性能)模式]+[(内容)组成] 模式有:Debug,DebugGame,Develop ...

  3. vim不用鼠标复制粘贴

    第一种方法(只能复制行): 在当前行3yy(表示复制3行,多行同理),然后鼠标移到需要粘贴的位置,按p,即可粘贴 第二种方法(无限制): 按v进入visual模式,移动光标(推荐使用hjkl,用熟后比 ...

  4. 0729pm命名空间

  5. java中throw和throws的区别

    throw和throws的区别: throws 用在方法声明后面,跟的是异常类名 可以跟多个异常类名,用逗号隔开 表示抛出异常,由该方法的调用者来处理 throws表示出现异常的一种可能性,并不一定会 ...

  6. lvs主备可以自由切换,vip落在主上的时候,端口无法telnet,业务连接不了

    lvs主备可以自由切换,vip落在主上的时候,端口无法telnet,业务连接不了 解决:将主上的keepalived重启,故障解除 原因:不可知 lvs常见故障原因: real server上的脚步没 ...

  7. Android Studio签名打包的两种方式

    签名打包的两种方式: 注:给我们自己开发的app签名,就代表着我自己的版权,以后要进行升级,也必须要使用相同的签名才行.签名就代表着自己的身份(即keystore),多个app可以使用同一个签名. 如 ...

  8. JavaScript 高性能笔记

    浏览器解析 JavaScript .CSS .DOM 时,一般都是单线程解析,所以,引用外部文件时的位置不同,UE体验也不同. 下面是 Yahoo 大牛 Nicholas C. Zakas 的 < ...

  9. Javascript数组方法(译)

    在JavaScript中,数组可以使用Array构造函数来创建,或使用[]快速创建,这也是首选的方法.数组是继承自Object的原型,并且他对typeof没有特殊的返回值,他只返回'object'. ...

  10. nginx安装启动

    参考:http://network.51cto.com/art/201005/198198_4.htm 下载nginx tar.gz安装包下载pcre tar.gz安装包 安装pcretar zxvf ...