C# 语音技术
2013-05-29 21:49
183 查看
1、使用DotNetSpeech.dll。
/// <summary>
/// 朗读
/// </summary>
/// <param name="text">要朗读的文本</param>
private void Read(string text)
{
SpVoice sv = new SpVoice();
sv.Rate = 0;//设置朗读速度
SpeechVoiceSpeakFlags SSF = SpeechVoiceSpeakFlags.SVSFlagsAsync;
sv.Speak(text, SSF);
}
/// <summary>
/// 生成声音文件
/// </summary>
/// <param name="text">要朗读的文本</param>
/// <param name="filePath">生成声音文件的路径</param>
/// <param name="fileName">生成声音文件的名称</param>
private void CreateFile(string text, string filePath,string fileName)
{
if (!Directory.Exists(filePath))
Directory.CreateDirectory(filePath);
SpVoice sv = new SpVoice();
SpeechVoiceSpeakFlags SVSF = SpeechVoiceSpeakFlags.SVSFlagsAsync;
SpeechStreamFileMode SSFM = SpeechStreamFileMode.SSFMCreateForWrite;
SpFileStream SFS = new SpFileStream();
SFS.Open(filePath+fileName, SSFM, false);
sv.AudioOutputStream = SFS;
sv.Speak(text, SVSF);
sv.WaitUntilDone(System.Threading.Timeout.Infinite);
SFS.Close();
}2、 使用System.Speech
SpeechSynthesizer ss = new SpeechSynthesizer();
//播放
if (ss != null)
{
ss.Dispose();
ss.SpeakAsync("朗读的文本");
}
//暂停
if (ss.State == SynthesizerState.Speaking)
{
ss.Pause();
}
//继续
if (reader.State == SynthesizerState.Paused)
{
ss.Resume();
}
//停止
if (ss != null)
{
ss.Dispose();
}
/// <summary>
/// 朗读
/// </summary>
/// <param name="text">要朗读的文本</param>
private void Read(string text)
{
SpVoice sv = new SpVoice();
sv.Rate = 0;//设置朗读速度
SpeechVoiceSpeakFlags SSF = SpeechVoiceSpeakFlags.SVSFlagsAsync;
sv.Speak(text, SSF);
}
/// <summary>
/// 生成声音文件
/// </summary>
/// <param name="text">要朗读的文本</param>
/// <param name="filePath">生成声音文件的路径</param>
/// <param name="fileName">生成声音文件的名称</param>
private void CreateFile(string text, string filePath,string fileName)
{
if (!Directory.Exists(filePath))
Directory.CreateDirectory(filePath);
SpVoice sv = new SpVoice();
SpeechVoiceSpeakFlags SVSF = SpeechVoiceSpeakFlags.SVSFlagsAsync;
SpeechStreamFileMode SSFM = SpeechStreamFileMode.SSFMCreateForWrite;
SpFileStream SFS = new SpFileStream();
SFS.Open(filePath+fileName, SSFM, false);
sv.AudioOutputStream = SFS;
sv.Speak(text, SVSF);
sv.WaitUntilDone(System.Threading.Timeout.Infinite);
SFS.Close();
}2、 使用System.Speech
SpeechSynthesizer ss = new SpeechSynthesizer();
//播放
if (ss != null)
{
ss.Dispose();
ss.SpeakAsync("朗读的文本");
}
//暂停
if (ss.State == SynthesizerState.Speaking)
{
ss.Pause();
}
//继续
if (reader.State == SynthesizerState.Paused)
{
ss.Resume();
}
//停止
if (ss != null)
{
ss.Dispose();
}
相关文章推荐
- 用C#实现语音技术
- [语音合成技术第二讲]C# 中使用语音合成技术(一)
- [转]中英文语音合成与中文语音识别技术在c#中的应用(一)
- 语音合成与识别技术在C#中的应用3
- [转]语音合成与识别技术在C#中的应用
- 用C#实现语音技术
- C# 语音技术
- 中英文语音合成与中文语音识别技术在c#中的应用(一)
- 语音合成与识别技术在C#中的应用
- 用C#实现语音技术
- 语音合成与识别技术在C#中的应用2
- 用C#实现语音技术
- 用C#实现语音技术
- 用C#实现语音技术开发者在线 Builder.com.cn 更新时间:2008-07-18作者: 来源:
- 用C#实现语音技术
- [转]中英文语音合成与中文语音识别技术在c#中的应用(二)
- 用c#实现语音技术
- 中文语音识别技术在c#中的应用(二)
- 有关在C#2008中语音开发技术
- 用C#实现语音技术