2012-07-29 40 views
-1

我正在處理文本到語音應用程序。我給了一個輸入字符串並通過按鈕進行轉換。當我點擊按鈕時,應用程序意外關閉。當輸入被硬編碼時,應用程序正常運行。應用程序意外停止,錯誤顯示

EditText text; 
String[] texts ; 
TextToSpeech tts; 
@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
    texts = new String[3]; 
    text = (EditText)findViewById(R.id.ttexttovoice); 
    //Editable debug = text.getText(); 
    texts[0] = text.getText().toString(); 
    Button b = (Button)findViewById(R.id.btexttovoice); 
    b.setOnClickListener(this); 
    tts = new TextToSpeech(textvoice.this,new TextToSpeech.OnInitListener(){ 

     @Override 
     public void onInit(int status) { 
      // TODO Auto-generated method stub 
      if(status!= TextToSpeech.ERROR) 
      { 
       tts.setLanguage(Locale.US); 

      } 
      } 
    }); 

} 

@Override 
protected void onPause() { 
    // TODO Auto-generated method stub 
    if(tts!= null) 
    { 
     tts.stop(); 
     tts.shutdown(); 
    } 
    super.onPause(); 
} 

@Override 
public void onClick(View v) { 
    // TODO Auto-generated method stub 
    Random r = new Random(); 
    String rn = texts[r.nextInt(3)]; 
    tts.speak(rn, TextToSpeech.QUEUE_FLUSH, null); 
} 

} 這裏是logcat的:

07-29 07:18:52.635: ERROR/AndroidRuntime(246): Uncaught handler: thread main exiting due to uncaught exception 
07-29 07:18:52.665: ERROR/AndroidRuntime(246): java.lang.NullPointerException: println needs a message 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.util.Log.println(Native Method) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.util.Log.i(Log.java:136) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.speech.tts.TextToSpeech.speak(TextToSpeech.java:673) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at org.textvoice.textvoice.onClick(textvoice.java:64) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.view.View.performClick(View.java:2364) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.view.View.onTouchEvent(View.java:4179) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.widget.TextView.onTouchEvent(TextView.java:6541) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.view.View.dispatchTouchEvent(View.java:3709) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1659) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1107) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.app.Activity.dispatchTouchEvent(Activity.java:2061) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1643) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.view.ViewRoot.handleMessage(ViewRoot.java:1691) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.os.Handler.dispatchMessage(Handler.java:99) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.os.Looper.loop(Looper.java:123) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at android.app.ActivityThread.main(ActivityThread.java:4363) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at java.lang.reflect.Method.invokeNative(Native Method) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at java.lang.reflect.Method.invoke(Method.java:521) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 
07-29 07:18:52.665: ERROR/AndroidRuntime(246):  at dalvik.system.NativeStart.main(Native Method) 
+0

你的方法中是否有任何'log'代碼行? – iTurki 2012-07-29 01:31:46

+1

你給'文本'中的第一項是一個值,但不是其他值?如果蘭特選擇1或2,你會發生什麼? – 2012-07-29 01:31:57

回答

0

我認爲文本[r.nextInt(3)]是null.pls保證文本[0]〜文本[2]具有值的字符串。

+0

這是整個代碼。沒有提到日誌代碼行。好的,如果文本[r.nextInt(3)]爲空我應該用什麼來代替文本[0]來將數組字符串作爲輸入。 – dan 2012-07-29 08:44:26