- A+
所属分类:.NET技术
System.Speech是.NET框架的一部分,提供了语音识别和语音合成的功能。通过使用System.Speech命名空间中的类,开发人员可以在.NET应用程序中实现语音识别功能。 在本文中,我将演示如何使用 System.Speech.NET,这是开发语音应用程序比较牛逼的内库。它适用于 .NET 4.x和.NET Core以上版本。它支持语音识别和文本到语音转换,并提供统一的 API。借助 System.Speech.NET,您可以轻松创建理解和响应自然语言输入的应用程序。本文将在这里重点介绍System.Speech的Speak 方法。
使用流程
这里我们使用winfrom来演示System.Speech的使用,流程如下:
1)创建一个文件夹并运行dotnet命令以创建一个winfrom新项目,也可以用vs新建winfrom。
dotnet new winforms
2) 打开“管理NuGet程序包“搜索System.Speech后安装nuget包。如下图
3)创建一个扩展类
这个主要扩展string的speak功能,后面能用上。
using System.Speech.Synthesis; namespace System { public static class SystemSpeechExtension { // 默认语音转换速率 const int PDefaultRate = 3; // 错误信息语音转换速率 const int PErrorRate = 4; /// <summary> /// 将字符串转换为语音并进行播放,使用默认速率。 /// </summary> /// <param name="text2speak">要转换为语音的字符串</param> public static void Speak(this string text2speak) { text2speak.Speak(PDefaultRate); } /// <summary> /// 将字符串转换为语音并进行播放,可以指定转换速率。 /// </summary> /// <param name="text2speak">要转换为语音的字符串</param> /// <param name="rate">语音转换速率</param> public static void Speak(this string text2speak, int rate) { var voice = new SpeechSynthesizer(); voice.SetOutputToDefaultAudioDevice(); voice.Rate = rate; voice.Speak(text2speak); } /// <summary> /// 将错误信息转换为语音进行播放,在调试模式下使用 PErrorRate 速率。 /// </summary> /// <param name="text2speak">要转换为语音的错误信息</param> public static void SpeakError(this string text2speak) { #if(DEBUG) $"Error {text2speak} while debugging!".Speak(PErrorRate); #endif } } }
4)新建一个winfrom窗体使用这个扩展类,效果如下:
按钮代码如下:
public partial class Form1 : Form { public Form1() { InitializeComponent(); } /// <summary> /// 当按钮1被点击时,将文本框中的内容转换为语音并进行播放。 /// </summary> private void button1_Click(object sender, EventArgs e) => this.textBox1.Text.Speak(); /// <summary> /// 当按钮2被点击时,将文本框中的内容以指定的速率进行语音转换并播放。 /// </summary> private void button2_Click(object sender, EventArgs e) => this.textBox1.Text.Speak(3); /// <summary> /// 当按钮3被点击时,首先将一条指定的文本转换为语音并播放,然后在一个 try-catch 块中故意引发异常并捕获它。 /// 异常消息将被转换为语音并作为错误信息进行播放。 /// </summary> private void button3_Click(object sender, EventArgs e) { "请注意, 未填写内容,请填写内容!".Speak(); try { var n = 0; var i = 0; var error = n / i; } catch (Exception ex) { ex.Message.SpeakError(); } } }
这样代码部分全部写完,大家可以点击按钮来试一试了。
结语
本文介绍了System.Speech的文字转语音功能,并用案例介绍了它的使用流程。System.Speech还有很多功能,比如语音识别、音频输入和输出控制等,篇幅有限这里就不在介绍,感兴趣可以到官网查阅API来了解它使用方法。希望本文对你有所收获,你对System.Speech有什么看法欢迎留言或者吐槽本文。
来源公众号:DotNet开发跳槽