1

我有一个刷新的文本,每次发生这种情况。

speak()我用这种结构调用位于另一个类中的静态方法方法:

public class Voc {

    static TextToSpeech mytts;

    public static void speak(String myText){
       mytts=new TextToSpeech(c, new TextToSpeech.OnInitListener() {
        //.........parameters and config not related to issue........
       }
       mytts.speak();
    }

    public static off(){
       mytts.stop();
       mytts.shutdown();
    }

}

问题是,如果我off()在多次speak()调用后调用,tts 会继续说话。如果我speak()只调用一次而不是像刷新方法中发生的那样多次调用,则不会发生这种情况。这使我怀疑该off()方法不适用于所有实例,尽管我已将所有new TextToSpeech(...)调用分配给类中的相同静态字段Voc

我该如何解决这个问题?

4

1 回答 1

2

您的问题是由于您在每次调用 speak() 时实例化一个新的 TextToSpeech 对象,这不是必需的。通过我在下面提供的更新,您可以关闭并重新打开一个 TTS 对象,而不是多个,因此当您关闭它时,单个 TTS 对象将停止并且您的问题不再存在。

我已经在我的手机上对此进行了测试,它应该可以完全按照您的需要工作。

请在下面检查我的更新代码:

更新了声乐课

import android.content.Context;
import android.os.Build;
import android.speech.tts.TextToSpeech;
import android.util.Log;
import java.util.Locale;

public class Voc {

    static TextToSpeech mytts = null;

    public static void init(Context c){
        mytts=new TextToSpeech(c, new TextToSpeech.OnInitListener() {
            @Override
            public void onInit(int status) {
                if(status == TextToSpeech.SUCCESS){
                    int result=mytts.setLanguage(Locale.US);
                    if(result==TextToSpeech.LANG_NOT_SUPPORTED ||
                            result==TextToSpeech.LANG_MISSING_DATA){
                        Log.d("error", "Language not supported");
                    }
                } else
                    Log.d("error", "TTS failed :(");
            }
        });
    }

    public static void speak(final String myText){  
        if(mytts != null) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                mytts.speak(myText, TextToSpeech.QUEUE_FLUSH, null, null);
            } else {
                //cover all versions...
                mytts.speak(myText, TextToSpeech.QUEUE_FLUSH, null);
            }
        }
    }

   public static void off(){
        if(mytts !=null) {
            mytts.stop();
            //mytts.shutdown();  //calling this here is not what we want
        }
   }

   public static void shutdown(){
        if(mytts !=null) {
            mytts.shutdown();  //if you need call shutdown with this method
        }
   }
}

测试的主要活动

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Voc.init(getApplicationContext()); //this is the method that sets everything up

        Button onButton = (Button) findViewById(R.id.button_on);
        onButton.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                Voc.speak("blah blah blah blah blah blah blah blah");

            }
        });

        Button offButton = (Button) findViewById(R.id.button_off);
        offButton.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                Voc.off();
            }
        });
    }
}

测试布局示例

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.viatechsystems.tts.MainActivity">

<Button
    android:id="@+id/button_on"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Click me for TTS"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintRight_toRightOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintHorizontal_bias="0.292"
    app:layout_constraintVertical_bias="0.498" />

<Button
    android:id="@+id/button_off"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Off"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintLeft_toLeftOf="@+id/button_on"
    app:layout_constraintRight_toRightOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintHorizontal_bias="0.75"
    app:layout_constraintVertical_bias="0.498" />

</android.support.constraint.ConstraintLayout>
于 2018-06-14T15:48:00.683 回答