2012-04-01 6 views
6

Sono nuovo nello sviluppo di Android e affronta un problema durante l'utilizzo di AndEngine. Sto cercando di eseguire un'applicazione vuota ma ottenere un errore di runtime come segue:AndEngine - Impossibile istanziare l'attività

04-01 21:56:16.326: W/dalvikvm(280): Unable to resolve superclass of Lcom/MyApps/TestApp/TestAppActivity; (31) 
04-01 21:56:16.326: W/dalvikvm(280): Link of class 'Lcom/MyApps/TestApp/TestAppActivity;' failed 
04-01 21:56:16.336: D/AndroidRuntime(280): Shutting down VM 
04-01 21:56:16.336: W/dalvikvm(280): threadid=1: thread exiting with uncaught exception (group=0x4001d800) 
04-01 21:56:16.376: E/AndroidRuntime(280): FATAL EXCEPTION: main 
04-01 21:56:16.376: E/AndroidRuntime(280): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.MyApps.TestApp/com.MyApps.TestApp.TestAppActivity}: java.lang.ClassNotFoundException: com.MyApps.TestApp.TestAppActivity in loader dalvik.system.PathClassLoader[/data/app/com.MyApps.TestApp-1.apk] 
04-01 21:56:16.376: E/AndroidRuntime(280): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585) 
04-01 21:56:16.376: E/AndroidRuntime(280): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 
04-01 21:56:16.376: E/AndroidRuntime(280): at android.app.ActivityThread.access$2300(ActivityThread.java:125) 
04-01 21:56:16.376: E/AndroidRuntime(280): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 
04-01 21:56:16.376: E/AndroidRuntime(280): at android.os.Handler.dispatchMessage(Handler.java:99) 
04-01 21:56:16.376: E/AndroidRuntime(280): at android.os.Looper.loop(Looper.java:123) 
04-01 21:56:16.376: E/AndroidRuntime(280): at android.app.ActivityThread.main(ActivityThread.java:4627) 
04-01 21:56:16.376: E/AndroidRuntime(280): at java.lang.reflect.Method.invokeNative(Native Method) 
04-01 21:56:16.376: E/AndroidRuntime(280): at java.lang.reflect.Method.invoke(Method.java:521) 
04-01 21:56:16.376: E/AndroidRuntime(280): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
04-01 21:56:16.376: E/AndroidRuntime(280): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
04-01 21:56:16.376: E/AndroidRuntime(280): at dalvik.system.NativeStart.main(Native Method) 
04-01 21:56:16.376: E/AndroidRuntime(280): Caused by: java.lang.ClassNotFoundException: com.MyApps.TestApp.TestAppActivity in loader dalvik.system.PathClassLoader[/data/app/com.MyApps.TestApp-1.apk] 
04-01 21:56:16.376: E/AndroidRuntime(280): at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243) 
04-01 21:56:16.376: E/AndroidRuntime(280): at java.lang.ClassLoader.loadClass(ClassLoader.java:573) 
04-01 21:56:16.376: E/AndroidRuntime(280): at java.lang.ClassLoader.loadClass(ClassLoader.java:532) 
04-01 21:56:16.376: E/AndroidRuntime(280): at android.app.Instrumentation.newActivity(Instrumentation.java:1021) 
04-01 21:56:16.376: E/AndroidRuntime(280): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577) 
04-01 21:56:16.376: E/AndroidRuntime(280): ... 11 more 

Il manifesto utilizzato:

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="com.MyApps.TestApp" 
    android:versionCode="1" 
    android:versionName="1.0" > 

    <uses-sdk android:minSdkVersion="8" /> 
    <uses-permission android:name="android.permission.WAKE_LOCK" /> 

    <application 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name" > 
     <activity 
      android:name=".TestAppActivity" 
      android:label="@string/app_name" > 
      <intent-filter> 
       <action android:name="android.intent.action.MAIN" /> 

       <category android:name="android.intent.category.LAUNCHER" /> 
      </intent-filter> 
     </activity> 
    </application> 

</manifest> 

Ho provato a mettere l'intero nome del pacchetto, invece di .TestAppActivity ma senza alcuna fortuna. Tuttavia, quando ho esteso TestAppActivity da Activity invece di BaseGameActivity, ha funzionato.

Ogni aiuto è apprezzato, Sami

risposta

8

L'errore Unable to resolve superclass of Lcom/MyApps/TestApp/TestAppActivity e che funziona quando si eredita dalla Activity suggerirebbe che non si è compresa la biblioteca AndEngine nel vostro APK — quindi in fase di esecuzione BaseGameActivity non può essere trovato.

Assicurarsi che la dipendenza AndEngine si trovi nella directory libs nel progetto Android; non solo aggiunto al tuo classpath Eclipse.

Infatti, se disponi dell'ultimo plug-in per Android Eclipse, tutte le dipendenze verranno automaticamente incluse nell'APK se le inserisci in libs.

+0

Grazie mille. Problema risolto. L'ho aggiunto solo al classpath – Sami

+1

Dopo aver aggiornato ADT alla versione più recente, ho scoperto lo stesso problema. Ho avuto andengine.jar nella cartella lib, aggiunto alle librerie di riferimento e ha funzionato finora. Ora, ho dovuto cambiare la lib in libs. Devono davvero rilasciare il nuovo SDK ogni 5 minuti? Non possono creare UN ambiente stabile? – Yar

+3

Personalmente ho trovato molto più semplice fare semplicemente riferimento al progetto AndEngine piuttosto che copiare e incollare il file .jar nella directory libs. Ciò avviene tramite Proprietà -> Android e quindi fa riferimento ai progetti AndEngine come librerie. – Dan

2

Avevo un messaggio di errore praticamente indentico, e il mio problema era che avevo installato la versione errata di JDK, quando ho scaricato e installato JDK6 invece di 7 funzionava correttamente. Nel caso in cui questo salverà chiunque dall'attraversare l'incubo vivente che ho appena vissuto, lascerò questo qui.