- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个刷新的文本,每次都会发生这种情况。
我调用位于另一个具有以下结构的类中的静态方法方法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();
}
}
问题是,如果我在多次调用 speak()
后调用 off()
,tts 会继续说话。如果我仅调用 speak()
一次而不是像刷新方法中那样多次调用,则不会发生这种情况。这让我怀疑 off()
方法并不适用于所有实例,尽管我已将所有 new TextToSpeech(...)
调用分配给类 Voc
中的同一静态字段。
如何解决这个问题?
最佳答案
您的问题是由于您在每次调用 talk() 时实例化了一个新的 TextToSpeech 对象,这是不需要的。通过我在下面提供的更新,您可以关闭并重新打开一个 TTS 对象,而不是多个,因此当您关闭它时,单个 TTS 对象将停止,并且您的问题不再存在。
我已经在我的手机上对此进行了测试,它应该完全按照您的需要工作。
请检查下面我更新的代码:
更新了 Voc 类
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
}
}
}
测试的主要 Activity
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>
关于java - TextToSpeech 无法正确停止,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50858685/
对于 Android 上的新 TextToSpeech 实例,我遇到了 onInit(..) 的意外问题。 我发现的所有代码示例都假定在调用 onOnit(..) 之前将新实例返回给调用者,以便返回值
我试着像这样使用它 int result2 = tts_hebrew.setLanguage(Locale.iw); 但我无法识别为 Locale.iw。 在http://developer.andr
更新:经过一番挖掘,我设法在 Logcat 中找到了一些信息。见底部。 编辑 2:我现在从头开始创建了一个新 Activity 来减少这个问题。它仍然不能正常工作。这是代码: public class
我正在尝试在不同的类中调用 TextToSpeech。这是我的类(class)现在的样子: //MainActivity.java public class MainActivity extends
我正在创建一个涉及短信的 Android 应用程序,其中一个功能是输入时会读出每个字母。我正在使用TextToSpeech。 我让它在一个测试项目中工作,但是当将它集成到我自己的项目中时,我收到一个未
我正在使用 TextToSpeech 向我的联系人中的某人发送短信。我使用一种非常丑陋的方式来做到这一点,因为我需要以一种方式说出所有表达式“发送消息到联系人短信是你好”。最好是像“发送消息”这样的应
我的安卓应用因为这个原因被亚马逊拒绝了。 当电话打进来时,我正在播放这个 TextToSpeech。他们要我停止播放。我该怎么做? 最佳答案 在实现 TextToSpeech 的服务或 Activit
我的应用程序正在调用广播接收器来读取传入的文本消息并大声说出来。我的 Broadcast Receiver 被正确调用,它正确读取文本消息,但是当涉及到 speak() 方法时,它就崩溃了。这是我的代
我有一个刷新的文本,每次都会发生这种情况。 我调用位于另一个具有以下结构的类中的静态方法方法speak(): public class Voc { static TextToSpeech my
由于内存不足的情况(在程序中,而不是程序员),我的应用程序一直在崩溃。 MAT 显示我的 Activity 的副本有时会在屏幕旋转时保留下来,并且唯一使伪造副本保持 Activity 状态的对象是每个
我希望能够将文本中的语音更改为语音 API,例如更改: 从女性到男性的声音。 让声音更清晰 改变语速 如果可能的话,请有人告诉我。谢谢。 最佳答案 您可以通过 addSpeech() 为特定字符串提供
我正在 TextToSpeech 上创建一个应用程序。但是当我试图运行时,它会在下一行抛出异常。 tts.speak(ruleOne, TextToSpeech.QUEUE_ADD, null); H
我正在使用下面的库来实现 TextToSpeech 功能来说话 - 'net.gotev:speech:1.3.1' 现在我需要将所有国家/地区的口音更改为我尝试过的美国英语 - Speech.get
使用 Android TextToSpeech 时,有什么方法可以指定语音的性别,例如 tts.setGender(TextToSpeech.MALE)或 tts.speak("Hello ") ?
@SuppressWarnings("deprecation") private void saveAudio(String text) { HashMap myHashRender = ne
The bounty在2天后过期。这个问题的答案有资格获得+50声望奖励。 Nerdy Bunz希望引起更多关于此问题的注意。 作为一项实验,以及一种迫使我自己了解tts在Android上工作原理的方
我是 Java 新手 我正在尝试使用 TextToSpeech,我有 Referenced libraries还有这个.java code通过具体的例子。 我的Main.java: package m
我需要调用synthesizeToFile来创建一些音频文件,并且我需要知道它何时完成创建所有这些文件,以便通知用户。 我已经阅读了其他问题,但没有找到适合我的问题,或者该问题与 speak 功能相关
我在onUteranceComplete()中连续调用文本转语音speak()方法,当事件发生时。说话方法工作正常,它不断地朗读文本,但我在这段代码中遇到了一个奇怪的问题。 Activity 结束后,
我试图做一些非常简单的事情,或者我认为它是。 在我的蓝牙聊天中,我设置了 public static boolean potato = false; 在我的 MainActivity 的 onCrea
我是一名优秀的程序员,十分优秀!