Я пытаюсь создать приложение, которое использует textToSpeak. По-видимому, textToSpeak должен использоваться в рамках действия для его работы.Android - Нужна активность, но не нужна активность?
Однако я не могу иметь textToSpeak в нормальном классе java, поэтому я могу создать его экземпляр в текущем запуске и вызвать метод, который заставит textToSpeech высказывать определенный текст.
мне удалось получить TTS работать, когда в отдельном проекте, и это работает деятельность, однако я не могу получить его экземпляр в аа другую ...
Speak класс (который имеет TTS, проблематичный линия "частные TextToSpeech TTS = новый TextToSpeech (это, это);". - обеспечивает неперехваченное исключение
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);
}
}
Запуск активности (под редакцией, чтобы показать, как я хочу использовать класс речи)
public class Text_entry extends Activity implements OnTouchListener{
private Speech speech = new Speech();
public boolean onTouch(View v, MotionEvent event) {
speech.changeText(toRead);
speech.speak();
}
}
Эта настройка работает отлично для других объектов, однако, поскольку 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
Это, безусловно, является шагом в правильном направлении. Я больше не получаю никаких ошибок и состояний Logcat. Я успешно привязан к com.google.android.tts и подключен к службе TTS. Единственная проблема в том, что звука нет :( – user2052839
@ user2052839 Является ли телефон в режиме отладки USB Это может привести к тому, что звук не выйдет. TTS также может потребоваться некоторое время для инициализации, прежде чем он сможет говорить. – Eric
Кодирование, безусловно, работает на эмуляторе ... просто нужно выяснить, почему это не на телефоне. а не только это, что не будет работать. Это отдельный пример, где TTS находится в основном действии, которое также не будет работать на телефоне. – user2052839