【发布时间】:2026-02-06 22:45:01
【问题描述】:
我是 Android 开发的新手,我正在尝试在(android 4.4 平台和三星 Galaxy S4)上运行基本的文本转语音 (TTS) 代码,但应用程序一旦打开就会崩溃。给出了主要活动代码和系统消息的捕获屏幕。
package com.example.ttscode;
import java.util.Locale;
import android.app.Activity;
import android.os.Bundle;
import android.speech.tts.TextToSpeech;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
public class MainActivity extends Activity implements
TextToSpeech.OnInitListener {
/** Called when the activity is first created. */
private TextToSpeech tts;
private Button btnSpeak;
private EditText txtText;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tts = new TextToSpeech(this, this);
btnSpeak = (Button) findViewById(R.id.action_settings);
txtText = (EditText) findViewById(R.id.action_settings);
// button on click event
btnSpeak.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View arg0) {
speakOut();
}
});
}
@Override
public void onDestroy() {
// Don't forget to shutdown tts!
if (tts != null) {
tts.stop();
tts.shutdown();
}
super.onDestroy();
}
@Override
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 {
btnSpeak.setEnabled(true);
speakOut();
}
} else {
Log.e("TTS", "Initilization Failed!");
}
}
private void speakOut() {
String text = txtText.getText().toString();
tts.speak(text, TextToSpeech.QUEUE_FLUSH, null);
}
}
图片在此链接http://i.stack.imgur.com/CYvz2.jpg
这是logcat中的红色文字:
04-15 23:38:41.026:E/AndroidRuntime(32189):致命异常:主要 04-15 23:38:41.026: E/AndroidRuntime(32189): 进程: com.example.ttscode, PID: 32189 04-15 23:38:41.026: E/AndroidRuntime(32189): java.lang.RuntimeException: 无法启动活动 ComponentInfo{com.example.ttscode/com.example.ttscode.MainActivity}: java.lang.NullPointerException 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2305) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2363) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.app.ActivityThread.access$900(ActivityThread.java:161) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1265) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.os.Handler.dispatchMessage(Handler.java:102) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.os.Looper.loop(Looper.java:157) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.app.ActivityThread.main(ActivityThread.java:5356) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 java.lang.reflect.Method.invokeNative(Native Method) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 java.lang.reflect.Method.invoke(Method.java:515) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1265) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081) 04-15 23:38:41.026: E/AndroidRuntime(32189): at dalvik.system.NativeStart.main(Native Method) 04-15 23:38:41.026: E/AndroidRuntime(32189): 引起: java.lang.NullPointerException 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 com.example.ttscode.MainActivity.onCreate(MainActivity.java:33) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.app.Activity.performCreate(Activity.java:5426) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105) 04-15 23:38:41.026: E/AndroidRuntime(32189): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2269) 04-15 23:38:41.026: E/AndroidRuntime(32189): ... 11 更多 04-15 23:38:47.171: I/Process(32189): 发送信号。 PID:32189 SIG:9
【问题讨论】:
-
向我们展示您的 logcat 崩溃输出
-
如果你想用谷歌做这个,我可以帮忙,我建议这样,
-
@ErsinGülbahar 你的意思是谷歌 TTS 引擎?
-
是的,使用谷歌翻译
-
@panini 这里是 logcat i.stack.imgur.com/bHHBI.jpg,感谢您的回复
标签: android crash text-to-speech