.NET使用System.Speech轻松读取文本
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开发跳槽