Java Android-需要活动,但不要';你不想参加活动吗?

Java Android-需要活动,但不要';你不想参加活动吗?,java,android,exception,android-activity,text-to-speech,Java,Android,Exception,Android Activity,Text To Speech,我正在尝试创建一个使用textToSpeak的应用程序。显然,textToSpeak必须在活动中使用才能正常工作 但是,我不希望在普通java类中有textToSpeak,这样我就可以在当前运行的活动中实例化它,并调用一个方法,使textToSpeech说出特定的文本 我已经设法让TTS工作时,在一个单独的项目,这是正在运行的活动,但我不能让它在一个不同的实例化一个 Speak类(包含TTS,有问题的行是“private TextToSpeech TTS=new TextToSpeech(thi

我正在尝试创建一个使用textToSpeak的应用程序。显然,textToSpeak必须在活动中使用才能正常工作

但是,我不希望在普通java类中有textToSpeak,这样我就可以在当前运行的活动中实例化它,并调用一个方法,使textToSpeech说出特定的文本

我已经设法让TTS工作时,在一个单独的项目,这是正在运行的活动,但我不能让它在一个不同的实例化一个

Speak类(包含TTS,有问题的行是“private TextToSpeech TTS=new TextToSpeech(this,this);”)-提供未捕获的异常

import java.util.Locale;

import android.app.Activity;
import android.os.Bundle;
import android.speech.tts.TextToSpeech;
import android.util.Log;

public class Speech extends Activity implements TextToSpeech.OnInitListener {

    private TextToSpeech tts = new TextToSpeech(this, this);
    private String toRead;

    public void speak()
    {
        speakOut();
    }

    public void changeText(String changeTo)
    {
        toRead = changeTo;
    }

    @Override
    public void onDestroy() {
        // Don't forget to shutdown tts!
        if (tts != null) {
            tts.stop();
            tts.shutdown();
        }
        super.onDestroy();
    }


    public void onInit(int status) {

        if (status == TextToSpeech.SUCCESS) {

            int result = tts.setLanguage(Locale.US);

            if (result == TextToSpeech.LANG_MISSING_DATA
                    || result == TextToSpeech.LANG_NOT_SUPPORTED) {
                Log.e("TTS", "This Language is not supported");
            } else {
                speakOut();
            }

        } else {
            Log.e("TTS", "Initilization Failed!");
        }

    }

    private void speakOut() {
        tts.speak(toRead, TextToSpeech.QUEUE_FLUSH, null);
        }
    }
运行活动(编辑以显示如何使用speech类)

这个设置对其他对象很好,但是因为TTS需要是活动的一部分(如果语音不扩展活动,则无法识别),我似乎无法工作。有人能提供解决方案吗

LogCat

02-16 16:52:46.698: D/AndroidRuntime(22541): Shutting down VM
02-16 16:52:46.698: W/dalvikvm(22541): threadid=1: thread exiting with uncaught exception (group=0x415fe300)
02-16 16:52:46.703: E/AndroidRuntime(22541): FATAL EXCEPTION: main
02-16 16:52:46.703: E/AndroidRuntime(22541): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{org.BT/org.BT.Text_entry}: java.lang.NullPointerException
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2024)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2125)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.app.ActivityThread.access$600(ActivityThread.java:140)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1227)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.os.Handler.dispatchMessage(Handler.java:99)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.os.Looper.loop(Looper.java:137)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.app.ActivityThread.main(ActivityThread.java:4898)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at java.lang.reflect.Method.invokeNative(Native Method)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at java.lang.reflect.Method.invoke(Method.java:511)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at dalvik.system.NativeStart.main(Native Method)
02-16 16:52:46.703: E/AndroidRuntime(22541): Caused by: java.lang.NullPointerException
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.content.ContextWrapper.getContentResolver(ContextWrapper.java:91)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.speech.tts.TtsEngines.getDefaultEngine(TtsEngines.java:75)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.speech.tts.TextToSpeech.getDefaultEngine(TextToSpeech.java:1235)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.speech.tts.TextToSpeech.initTts(TextToSpeech.java:595)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.speech.tts.TextToSpeech.<init>(TextToSpeech.java:553)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.speech.tts.TextToSpeech.<init>(TextToSpeech.java:527)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.speech.tts.TextToSpeech.<init>(TextToSpeech.java:512)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at org.BT.Speech.<init>(Speech.java:12)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at org.BT.Text_entry.<init>(Text_entry.java:48)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at java.lang.Class.newInstanceImpl(Native Method)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at java.lang.Class.newInstance(Class.java:1319)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.app.Instrumentation.newActivity(Instrumentation.java:1057)
02-16 16:52:46.703: E/AndroidRuntime(22541):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2015)
02-16 16:52:46.703: E/AndroidRuntime(22541):    ... 11 more
02-16 16:52:46.698:D/AndroidRuntime(22541):关闭虚拟机
02-16 16:52:46.698:W/dalvikvm(22541):threadid=1:线程以未捕获异常退出(组=0x415fe300)
02-16 16:52:46.703:E/AndroidRuntime(22541):致命异常:主
02-16 16:52:46.703:E/AndroidRuntime(22541):java.lang.RuntimeException:无法实例化活动组件信息{org.BT/org.BT.Text_entry}:java.lang.NullPointerException
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2024)
02-16 16:52:46.703:E/AndroidRuntime(22541):位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2125)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.app.ActivityThread.access$600(ActivityThread.java:140)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1227)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.os.Handler.dispatchMessage(Handler.java:99)上
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.os.Looper.loop(Looper.java:137)
02-16 16:52:46.703:E/AndroidRuntime(22541):位于android.app.ActivityThread.main(ActivityThread.java:4898)
02-16 16:52:46.703:E/AndroidRuntime(22541):位于java.lang.reflect.Method.Invokenactive(本机方法)
02-16 16:52:46.703:E/AndroidRuntime(22541):在java.lang.reflect.Method.invoke(Method.java:511)
02-16 16:52:46.703:E/AndroidRuntime(22541):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
02-16 16:52:46.703:E/AndroidRuntime(22541):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
02-16 16:52:46.703:E/AndroidRuntime(22541):在dalvik.system.NativeStart.main(本机方法)
02-16 16:52:46.703:E/AndroidRuntime(22541):由以下原因引起:java.lang.NullPointerException
02-16 16:52:46.703:E/AndroidRuntime(22541):位于android.content.ContextWrapper.getContentResolver(ContextWrapper.java:91)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.speech.tts.TtsEngines.getDefaultEngine(TtsEngines.java:75)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.speech.tts.TextToSpeech.getDefaultEngine(TextToSpeech.java:1235)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.speech.tts.TextToSpeech.initTts(TextToSpeech.java:595)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.speech.tts.TextToSpeech.(TextToSpeech.java:553)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.speech.tts.TextToSpeech.(TextToSpeech.java:527)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.speech.tts.TextToSpeech.(TextToSpeech.java:512)
02-16 16:52:46.703:E/AndroidRuntime(22541):org.BT.Speech.(Speech.java:12)
02-16 16:52:46.703:E/AndroidRuntime(22541):在org.BT.Text_条目上。(Text_条目.java:48)
02-16 16:52:46.703:E/AndroidRuntime(22541):位于java.lang.Class.newInstanceImpl(本机方法)
02-16 16:52:46.703:E/AndroidRuntime(22541):位于java.lang.Class.newInstance(Class.java:1319)
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.app.Instrumentation.newActivity(Instrumentation.java:1057)上
02-16 16:52:46.703:E/AndroidRuntime(22541):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2015)
02-16 16:52:46.703:E/AndroidRuntime(22541):…还有11个

不要扩展
活动
。将
上下文
传递给构造函数:

public class Speech implements TextToSpeech.OnInitListener {
    private Context mContext;
    private TextToSpeech tts;

    public Speech(Context c) {
        mContext = c;
        tts = new TextToSpeech(c, this);
    }

    // Rest of class
}
然后像这样构造它:

public class Text_entry extends Activity implements OnTouchListener{
    private Speech speech;

    public void onCreate(Bundled saved) {
        super.onCreate(saved);
        speech = new Speech(this);
    }
    public boolean onTouch(View v, MotionEvent event) {
        speech.changeText(toRead);
        speech.speak();
    }
}

这无疑是朝着正确方向迈出的一步。我不再收到任何错误和Logcat状态,我已成功绑定到com.google.android.tts并连接到tts服务。现在唯一的问题是没有声音:(@user2052839手机是否处于USB调试模式?这可能会导致无法发出声音。TTS也可能需要一些时间进行初始化,然后才能说话。编码肯定可以在模拟器上运行…只是要弄清楚为什么它不在手机上。不只是这一点不起作用-这是TTS位于主ac中的独立示例在手机上不起作用的活动also@user2052839我想,如果我是你,我会开始一个关于TTS不起作用的新问题(因为这个问题不会带来熟悉TTS的人)。我还会看看谷歌,看看是什么导致了这种行为。
public class Text_entry extends Activity implements OnTouchListener{
    private Speech speech;

    public void onCreate(Bundled saved) {
        super.onCreate(saved);
        speech = new Speech(this);
    }
    public boolean onTouch(View v, MotionEvent event) {
        speech.changeText(toRead);
        speech.speak();
    }
}