我的应用程序由视障人士使用,因此它严重依赖文本到语音。应用程序调用 API 并向用户读出负载(使用 android.speech.tts.TextToSpeech)一些相关信息。
一切正常,除了我注意到有时文本到语音的初始化需要 10 秒或更长时间,这是我的应用程序的主要瓶颈。
我想知道是否有人对如何优化我的代码来缓解这个问题有任何想法。
首先,我的应用程序启动一个活动来检查 TTS 数据。
Intent checkIntent = new Intent();
checkIntent.setAction(TextToSpeech.Engine.ACTION_CHECK_TTS_DATA);
startActivityForResult(checkIntent, MY_DATA_CHECK_CODE);
然后,使用活动的结果调用此方法。根据结果,文本到语音要么刚刚初始化(这几乎总是发生),要么在设备上安装了文本到语音(非常罕见)。
private TextToSpeech mTts;
@Override
protected void onActivityResult(
int requestCode, int resultCode, Intent data) {
if (requestCode == MY_DATA_CHECK_CODE) {
if (resultCode == TextToSpeech.Engine.CHECK_VOICE_DATA_PASS) {
// success, create the TTS instance
mTts = new TextToSpeech(this, this);
} else {
// missing data, install it
Intent installIntent = new Intent();
installIntent.setAction(
TextToSpeech.Engine.ACTION_INSTALL_TTS_DATA);
startActivity(installIntent);
}
}
}
最后,当所有这些都完成后,我的应用程序会调用一个 API,并且有几行如下所示:
mTts.speak("<Useful output here>", TextToSpeech.QUEUE_FLUSH, null);
感谢您的帮助!