本文介绍了Android O new TextToSpeech onRangeStart()回调的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

TTS UtteranceProgressListener的新回调函数onRangeStart()允许我们高亮显示TTS引擎所说的较长短语中的单个单词。回调在Android API参考https://developer.android.com/reference/android/speech/tts/UtteranceProgressListener.html#onRangeStart(java.lang.String,int,int,int)中定义,但我在任何地方都找不到当应用将短语(例如一句话)发送到TTS引擎进行语音生成时,如何实际定义短语中的范围的信息。

这些"范围"到底是什么,以及如何定义它们?或者它们是预定义为"单词"或以空格分隔的任何内容?

更多信息:我使用了Android O模拟器,并在我的TTS应用程序中创建了onRangeStart()回调,使用了Google TTS设置的不同声音,以查看是否自动定义了任何范围,并将调用该回调。没什么。可能必须以某种方式在Speech()调用的"Params"包中定义范围?

推荐答案

谷歌仍未记录此功能,对issue filed in their tracker的最新回应是"我们已将其推迟到未来版本,但暂时保留开放。"

同时,通过在我的TTS应用程序中实现onRangeStart()回调并使其显示调试输出,我看到"range"只是单词。我在使用谷歌TTS的英语语音时看到了这个回调,到目前为止,我还没有尝试过使用谷歌或其他公司的其他TTS语音来实现这一点。例如,大声朗读一句话:"这是一个需要大声朗读的句子。"在onRangeStart()中生成以下输出:

如果谷歌的某个人正式告诉我们"范围"只是简单的单词,那会很有帮助,至少目前是这样。

这篇关于Android O new TextToSpeech onRangeStart()回调的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

10-29 04:27