TTS 是 Text To Speech 的缩写,即“从文本到语音”,是人机对话的一部分,让机器可以说话。bash
TTS 技术对文本文件进行实时转换,转换时间之短能够秒计算。ide
TTS 不只能帮助有视觉障碍的人阅读计算机上的信息,更能增长文本文档的可读性。如今的 TTS 应用包括语音驱动的邮件以及声音敏感系统,并常与声音识别程序一块儿使用。this
从上面 Android 开发者官网的介绍能够看出 TextToSpeech 必须被实例化以后才能使用。spa
实现 TextToSpeech.OnInitListener 方法来获取实例化结果的监听。当你已经使用完 TextToSpeech 实例以后, 应该调用 shutdown() 方法来释放 TextToSpeech 所使用的本地资源。code
构造方法cdn
//使用默认的引擎
TextToSpeech(Context context, TextToSpeech.OnInitListener listener)
//使用指定的引擎
TextToSpeech(Context context, TextToSpeech.OnInitListener listener, String engine)
复制代码
主要方法blog
/**
* text 须要转成语音的文字
* queueMode 队列方式:
* QUEUE_ADD:播放完以前的语音任务后才播报本次内容
* QUEUE_FLUSH:丢弃以前的播报任务,当即播报本次内容
* params 设置TTS参数,能够是null。
* KEY_PARAM_STREAM:音频通道,能够是:STREAM_MUSIC、STREAM_NOTIFICATION、STREAM_RING等
* KEY_PARAM_VOLUME:音量大小,0-1f
* utteranceId:当前朗读文本的id
*/
textToSpeech.speak(content, TextToSpeech.QUEUE_FLUSH, null,i+"");
// 无论是否正在朗读TTS都被打断
textToSpeech.stop();
// 关闭,释放资源
textToSpeech.shutdown();
// 设置音调,值越大声音越尖(女生),值越小则变成男声,1.0是常规
textToSpeech.setPitch(0.5f);
// 设定语速,默认1.0正常语速
textToSpeech.setSpeechRate(1.5f);
复制代码
一、建立 TextToSpeech 类队列
//使用默认引擎,传入 Context 和 OnInitListener
TextToSpeech toSpeech = new TextToSpeech(this, this);
复制代码
二、重写 onInit() 方法资源
@Override
public void onInit(int status) {
if (status == TextToSpeech.SUCCESS) {
int result = toSpeech.setLanguage(Locale.CHINA);
if (result == TextToSpeech.LANG_MISSING_DATA
|| result == TextToSpeech.LANG_NOT_SUPPORTED) {
Toast.makeText(this, "数据丢失或不支持", Toast.LENGTH_SHORT).show();
}
if (toSpeech != null) {
toSpeech.setPitch(1.0f);// 设置音调,值越大声音越尖(女生),值越小则变成男声,1.0是常规
toSpeech.speak(list_task_little.get(currentPosition).getTask_content(),
TextToSpeech.QUEUE_FLUSH, null);
}
}
}
复制代码
调用方法 int result = toSpeech.setLanguage(Locale.CHINA); 设定语言为中文开发
在 onInit() 方法中判断初始化是否成功,初始化成功使用 toSpeech.setPitch(1.0f) 进行设置音调,值越大,音调越高。
使用 textToSpeech.setSpeechRate(1.5f) 设定语速,默认1.0正常语速。
三、释放资源
@Override
protected void onStop() {
super.onStop();
toSpeech.stop(); // 无论是否正在朗读TTS都被打断
toSpeech.shutdown(); // 关闭,释放资源
}
复制代码
当页面须要退出或者不在使用 TTS 的时候,进行资源释放。