0

我有多个Strings,每个包含 5 个句子。现在,我想一次一个地将这些传递给 android Text To Speech。这意味着,第一个字符串被传递给引擎,第二个文本应该在引擎完成讲话后传递。下面是我的代码。

List<String>textCollection = new ArrayList<String>();

//Add sentences to 'textCollection '. Code removed//

for(int i=0;i<textCollection.size();i++)
{
    while(tts.isSpeaking())
    {

     }

    Toast.makeText(Talk.this, ""+i, Toast.LENGTH_LONG).show();

    new SpeakTheText().execute(textCollection.get(i));

}

//This class will speak the text
    private class SpeakTheText extends AsyncTask<String,Void,String>
    {

        @Override
        protected String doInBackground(String... params) {
            // TODO Auto-generated method stub

            tts.speak(params[0], TextToSpeech.QUEUE_FLUSH, null);
            return null;
        }

    }

现在,不幸的是,正在发生的事情是出乎意料的。语音引擎只是从这里和那里说出文本,而不是按顺序!它从不说出第一个文本,只是从某个地方选择一个文本并阅读它。为什么会这样?

4

2 回答 2

2

你想改变 tts 的参数

tts.speak(params[0], TextToSpeech.QUEUE_ADD, null);

在我的应用程序中运行良好。

于 2013-10-16T10:47:37.710 回答
1

您不需要为此使用 AsyncTask。

让你的班级实现OnUtteranceCompletedListener

像这样启动您的 TextToSpeech 对象:

textToSpeech = new TextToSpeech(context, this); // this being the class that implements OnUtteranceCompletedListener.

然后,一旦您的 textToSpeech 对象完成给定的字符串,它将调用该onUtteranceCompleted方法,您可以在该方法中告诉您的 textToSpeech 对象说出下一个句子(如果有的话)。

或者,您可以使用QUEUE_ADD标志而不是QUEUE_FLUSH标志。这会将新文本添加到队列的末尾,而不是用新文本替换现有文本。

希望这可以帮助 :)

于 2013-10-16T10:04:10.307 回答