上视频效果,真实运行
通过 C# Xamarin.Essential 库,只需要一句代码就可以实现
TextToSpeech.SpeakAsync(txtDoc.Text, cancelToken: cts.Token);
CancellationTokenSource 类,实现停止朗读功能。
CancellationTokenSource cts = new CancellationTokenSource();
await TextToSpeech.SpeakAsync(txtDoc.Text, cancelToken: cts.Token);
所以在另一个方法里,用Cancel()方法就能停止朗读。
if (cts?.IsCancellationRequested ?? true)
{
return;
}
cts.Cancel();
最后上完整代码:开始读,停止读按钮事件,直接调用下面两个方法实现读,和停止读
CancellationTokenSource cts;
public async Task SpeakNowDefaultSettings()
{
btnStartRead.IsEnabled = false;
btnCancelRead.IsEnabled = true;
cts = new CancellationTokenSource();
await TextToSpeech.SpeakAsync(txtDoc.Text, cancelToken: cts.Token);
btnStartRead.IsEnabled = true;
btnCancelRead.IsEnabled = false;
}
public void CancelSpeech()
{
if (cts?.IsCancellationRequested ?? true)
return;
cts.Cancel();
btnStartRead.IsEnabled = true;
btnCancelRead.IsEnabled = false;
}
恭喜您,看到这里就已经学会文章开始视频里的那个功能。 是不是C# 在移动端开发简单易学??
原理:Android和iOS都自带语音助手,通过编程,可以把要说的文本通过语音助手直接朗读,包括中文英文,甚至其它国语言。
Android可以通过安装语音引擎后,在设置->语言和输入法->文字输语音输出, 实现切换语音助手。然后C#编程直接将文本内容推给接口,实现文本朗读,而且代码很简单。 视频默认的是小米手机自带的小爱同学
划重点:
重点是此部分代码中的异步操作。由于语音朗读是文字越多,执行时间越长,所以是异步实现避免UI卡死。 朗读结束结束完成后,UI线程重新获得控制权,让界面上的按钮状态恢复切换。
可以看到上面完整代码 btnStartRead 和 btnCancelRead 的Enable状态切换 没有写在传统的button_click(object ,sender)事件里,因为写在里面是不会实现按钮状态切换的。 只有上述代码那样,这就可以实现UI线程重新获得控制权,让界面上的按钮状态恢复切换。 这可以说是async的方法里使用await状态字的意义
写在最后:
C# Xamarin.Essential 封装了Android.Speech 和iOS 里的文本到语音接口,保证2个平台统一调用,提供3个函数来实现文本朗读:
如果只是开发Android上的Speech语音合成,会多出更多不只上面三个,可以更自由定制化开发安卓生态里的语音和语音识别的功能。