C# 语音技术

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();

 

文字识别  ocr组件

上一篇:超大背包问题


下一篇:Leetcode 90. 子集 II