`
kevin19900306
  • 浏览: 448920 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

C#调用SAPI实现语音合成的两种方法

阅读更多

我们都知道现在的语音合成TTS是可以通过微软的SAPI实现的,好处我就不多说了,方便而已,因为在微软的操作系统里面就自带了这个玩意,主要的方式有两种:

1、使用COM组件技术,不管是C++,C#,Delphi都能玩的转,开发出来的东西在XP和WIN7都能跑。(要引入SpeechLib,好像在项目上点引用,然后选到系统COM吧,好久没弄,记不清楚了)
2、使用WIN7的windows api,其实最终还是调用了SAPI,所以开发出来的东西就只能在WIN7上面跑。

其实不管是哪一种,都是调用SAPI,可能后一种代码比较简单,使用已经安装的TTS引擎,现在一般用NeoSpeech,这个就不解释了,太强大了这个发音。。。

COM组件技术:
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 

在 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)) ; 
}
} 

第二种使用.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;
            }
        }
}
分享到:
评论
1 楼 i2312375734 2016-11-04  
除了中文发音还能有其他语言吗?

相关推荐

    C#中调用SAPI实现语音合成的2种方法

    以下是两种利用C#调用SAPI实现语音合 成的方法: 1. 使用COM组件技术: 这种方法适用于XP和Win7等较旧的操作系统。首先,你需要在项目中引用`SpeechLib`,这是一个COM组件,通常可以在项目属性的"引用"选项中找到并...

    c# 用SAPI实现语音识别及文本转换的详细教程

    在C#中实现语音识别和文本转换,通常我们会利用微软的Speech API(SAPI),这是一个强大的接口,允许开发者集成自然语言处理功能,包括语音识别和语音合成。本教程将深入探讨如何利用SAPI来实现这些功能。 首先,...

    C#中调用SAPI实现语音识别的2种方法

    通过微软的SAPI,不仅仅可以实现语音合成TTS,同样可以实现语音识别SR。下面我们就介绍并贴出相关代码。主要有两种方式: 1、使用COM组件技术,不管是C++,C#,Delphi都能玩的转,开发出来的东西在XP和WIN7都能跑。...

    C# SAPI 语音交互系统

    C#中的SAPI库主要由两个关键部分组成:语音合成(ISpVoice)和语音识别(ISpRecognizer)接口。 ### 语音合成(TTS) 使用ISpVoice接口,我们可以将文本转换为自然流畅的语音输出。以下是一些关键步骤: 1. **初始化...

    C# 语音合成及录音支持朗读中文

    在本文中,我们将深入探讨如何在C#环境中实现语音合成及录音功能,特别是针对中文文本的朗读。C#作为微软开发的一种面向对象的编程语言,提供了丰富的库和API来支持此类任务。在这个项目中,开发者对一个已有的语音...

    解决sapi不能再win7上运行。报组件未注册的错误。两种解决方案

    SAPI(Speech Application Programming Interface)是微软提供的一种用于开发语音识别和合成应用的接口,它允许程序员集成自然语言处理功能到他们的应用程序中。在Windows 7操作系统中,如果你遇到“组件未注册”的...

    C#登录语音提醒操作语音提醒[标准版]

    要实现实时的语音播报,我们通常会用到以下两种方法: 1. **Windows自带的SAPI(Speech Application Programming Interface)**: SAPI是Microsoft提供的一种语音合成工具,允许开发者在应用程序中集成语音合成...

    用C_开发基于MicrosoftSpeechSDK的语音应用程序

    ### 用C#开发基于Microsoft Speech SDK的语音应用程序 #### 0. 引言 长久以来,人类一直在努力实现让...无论是语音合成还是语音识别,都可以通过调用SDK中的接口来实现,极大地降低了开发门槛,提高了开发效率。

    C++语音识别

    Windows操作系统自 Vista 版本开始内置了SAPI(Speech API),这是一个用于语音识别和合成的强大工具。SAPI包括两个主要部分:SR(Speech Recognition)和TTS(Text To Speech)。我们关注的是SR部分,它提供了接口...

    CSHARP语音识别

    `SAPI.SpVoice`虽然主要涉及语音合成,但在了解了语音识别的基本原理和流程后,结合这两个方面的知识,可以实现更完整的语音应用解决方案。记得在实际项目中,不断尝试和优化,以提升用户体验。

    C#计算器源码

    开发者需要设置语音合成器的属性,如语速、音调,然后调用 Speak 方法将计算结果显示出来。 在项目的代码结构上,通常会有两个主要部分:UI事件处理和计算逻辑。UI事件处理主要是处理用户在界面上的交互,如点击...

    一个基于Windows Vista speech API5.3以及WPF技术的语音识别代码

    3. 开始语音识别:调用ISpRecognizer的SetInput方法指定音频输入源,然后启动识别。 4. 处理识别事件:订阅ISpeechRecoResult事件,如Result事件,当有新的识别结果时进行处理。 5. 结合WPF:将识别结果绑定到WPF UI...

    tts 例子(web例子和控制台例子)

    控制台例子通常更直接,可能使用C#、VB.NET等.NET语言调用SAPI接口实现TTS。通过Console.WriteLine命令输出的文本可以被转换成语音,这对于自动化脚本或者没有图形界面的应用场景非常有用。控制台应用还可能支持...

    SpeechTTS文字转语音朗读

    1. **TTS引擎接口**:C#中可以使用Windows自带的SAPI(Speech API)或者第三方库如Microsoft Azure的Text-to-Speech服务,创建一个TTS引擎接口,负责调用相应的API进行语音合成。 2. **文本处理模块**:处理输入的...

Global site tag (gtag.js) - Google Analytics