2012-09-23 4 views
0

안드로이드에서 tts 엔진을 사용하는 방법을 알고 싶기 때문에이 앱을 작성했습니다. 나는 내 전화 및 에뮬레이터에 얻을 응용 프로그램을 시작할 때android text to speech (tts)

는 그러나 "unfortanetly 앱이 들렸다해야한다", 나는 또한 로그 캣 첨부, 내가 여기에 누군가가 나에게

package com.example.textspeechdemi; 

import java.util.Locale; 

import android.os.Bundle; 
import android.app.Activity; 
import android.content.Intent; 
import android.speech.tts.TextToSpeech; 
import android.view.Menu; 
import android.widget.Toast; 

public class MainActivity extends Activity implements TextToSpeech.OnInitListener { 

Intent mIntent; 
String value; 
private TextToSpeech tts; 
int j; 

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    mIntent = getIntent(); 
    Bundle b = getIntent().getExtras(); 
    final String name = b.getString("name"); 
    j = name.toCharArray()[0]; 

    Intent checkIntent = new Intent(); 
    checkIntent.setAction(TextToSpeech.Engine.ACTION_CHECK_TTS_DATA); 
    startActivityForResult(checkIntent, RESULT_OK); 
    tts = new TextToSpeech(this, this); 
    tts.speak("Welcome", TextToSpeech.QUEUE_ADD, null); 





    final Thread t1 = new Thread() { 
     public void run() { 
      try { 

       Thread.sleep(10000); 
       finish(); 
       // this.destroy(); 
      } catch (Exception e) { 
       // TODO Auto-generated catch block 
       Toast.makeText(getApplicationContext(), e.getMessage(), 
         Toast.LENGTH_SHORT).show(); 
      } 
     } 
    }; 
    t1.start(); 
} 

protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
    if (requestCode == RESULT_OK) { 
     if (resultCode == TextToSpeech.Engine.CHECK_VOICE_DATA_PASS) { 
      // success, create the TTS instance 
      tts = new TextToSpeech(this, this); 
     } else { 
      // missing data, install it 
      Intent installIntent = new Intent(); 
      installIntent 
        .setAction(TextToSpeech.Engine.ACTION_INSTALL_TTS_DATA); 
      startActivity(installIntent); 
     } 
    } 

} 

public void onInit(int status) { 
    if (status == TextToSpeech.SUCCESS) { 
     Toast.makeText(this, 
       "Write and Listen engine is initialized & Ready", 
       Toast.LENGTH_LONG).show(); 
    } else if (status == TextToSpeech.ERROR) { 
     Toast.makeText(this, 
       "Error occurred while initializing Text-To-Speech engine", 
       Toast.LENGTH_LONG).show(); 
    } 
} 

protected void onDestroy() { 
    super.onDestroy(); 
    if (tts != null) { 
     tts.shutdown(); 
    } 
} 

} 

로그 캣을 도움이되기를 바랍니다 :

09-23 21:59:16.765: E/AndroidRuntime(731): FATAL EXCEPTION: main 
09-23 21:59:16.765: E/AndroidRuntime(731): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.textspeechdemi/com.example.textspeechdemi.MainActivity}: java.lang.NullPointerException 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956) 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981) 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.app.ActivityThread.access$600(ActivityThread.java:123) 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147) 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.os.Handler.dispatchMessage(Handler.java:99) 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.os.Looper.loop(Looper.java:137) 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.app.ActivityThread.main(ActivityThread.java:4424) 
09-23 21:59:16.765: E/AndroidRuntime(731): at java.lang.reflect.Method.invokeNative(Native Method) 
09-23 21:59:16.765: E/AndroidRuntime(731): at java.lang.reflect.Method.invoke(Method.java:511) 
09-23 21:59:16.765: E/AndroidRuntime(731): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
09-23 21:59:16.765: E/AndroidRuntime(731): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
09-23 21:59:16.765: E/AndroidRuntime(731): at dalvik.system.NativeStart.main(Native Method) 
09-23 21:59:16.765: E/AndroidRuntime(731): Caused by: java.lang.NullPointerException 
09-23 21:59:16.765: E/AndroidRuntime(731): at com.example.textspeechdemi.MainActivity.onCreate(MainActivity.java:26) 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.app.Activity.performCreate(Activity.java:4465) 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049) 
09-23 21:59:16.765: E/AndroidRuntime(731): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920) 
09-23 21:59:16.765: E/AndroidRuntime(731): ... 11 more 

이 내 매니페스트입니다 :

<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="com.example.textspeechdemi" 
    android:versionCode="1" 
    android:versionName="1.0" > 

    <uses-sdk 
     android:minSdkVersion="8" 
     android:targetSdkVersion="15" /> 

    <application 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name" 
     android:theme="@style/AppTheme" > 
     <activity 
      android:name=".MainActivity" 
      android:label="@string/title_activity_main" > 
      <intent-filter> 
       <action android:name="android.intent.action.MAIN" /> 

       <category android:name="android.intent.category.LAUNCHER" /> 
      </intent-filter> 
     </activity> 
    </application> 
<uses-permission android:name="android.permission.READ_PHONE_STATE"/> 
    <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE"/> 
    <uses-permission android:name="android.permission.MODIFY_PHONE_STATE" /> 
    <uses-permission android:name="android.permission.UPDATE_DEVICE_STATS" /> 
     <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" /> 
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
    <uses-permission android:name="android.permission.INTERNET" /> 
    <uses-permission android:name="android.permission.CALL_PHONE"></uses-permission> 
    <uses-permission android:name="android.permission.READ_CONTACTS" /> 
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 
</manifest> 

답변

0

로그 캣의 관련 라인 일 수 있습니다 양반, 내 생각 :

Caused by: java.lang.NullPointerException 
09-23 21:59:16.765: E/AndroidRuntime(731): at com.example.textspeechdemi.MainActivity.onCreate(MainActivity.java:26) 

충돌 때문에 당신은 getExtras()에서 Bundle가 null가 아닌 것을 확인 할 수 있습니다 라인 (26)에 뭔가하고 "이름"여분의 것을 일어나고 당신은에서 얻고 있음 Bundle 정말 있습니다.

1

onCreate(...) 방법의 26 번째 줄에 NullPointerException이 있습니다. 이것은 당신이 Bundle bActivity하지 않는 한 추가 데이터를 통과 한 무언가에 의해 시작되어, null는, 어쨌든 경우가 될 것입니다처럼

final String name = b.getString("name"); 

는 기본적으로 보이는 ... 것으로 보인다.

관련 문제