2010-10-28 4 views
0

J'ai une application qui fonctionne comme prévu lorsqu'il est exécuté sur l'API 8, mais quand je le lance sur une version ancienne API, il se bloque avec:NullPointerError inexpliqué lors du référencement drawable sur l'API <8

10-28 12:10:50.755: ERROR/AndroidRuntime(1864): Uncaught handler: thread main exiting due to uncaught exception 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.nw.caremeter/com.nw.caremeter.CareMeter}: android.view.InflateException: Binary XML file line #35: Error inflating class <unknown> 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2596) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2621) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.app.ActivityThread.access$2200(ActivityThread.java:126) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1932) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.os.Handler.dispatchMessage(Handler.java:99) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.os.Looper.loop(Looper.java:123) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.app.ActivityThread.main(ActivityThread.java:4595) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at java.lang.reflect.Method.invokeNative(Native Method) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at java.lang.reflect.Method.invoke(Method.java:521) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at dalvik.system.NativeStart.main(Native Method) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864): Caused by: android.view.InflateException: Binary XML file line #35: Error inflating class <unknown> 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.view.LayoutInflater.createView(LayoutInflater.java:513) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:563) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.view.LayoutInflater.rInflate(LayoutInflater.java:618) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.view.LayoutInflater.inflate(LayoutInflater.java:407) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.view.LayoutInflater.inflate(LayoutInflater.java:320) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.view.LayoutInflater.inflate(LayoutInflater.java:276) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:207) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.app.Activity.setContentView(Activity.java:1629) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at com.nw.caremeter.onCreate(CareMeter.java:48) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2544) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  ... 11 more 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864): Caused by: java.lang.reflect.InvocationTargetException 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.widget.ImageView.<init>(ImageView.java:105) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at java.lang.reflect.Constructor.constructNative(Native Method) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at java.lang.reflect.Constructor.newInstance(Constructor.java:446) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.view.LayoutInflater.createView(LayoutInflater.java:500) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  ... 22 more 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864): Caused by: android.content.res.Resources$NotFoundException: File res/drawable/needle_green.xml from drawable resource ID #0x7f020005 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.content.res.Resources.loadDrawable(Resources.java:1693) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.content.res.TypedArray.getDrawable(TypedArray.java:548) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.widget.ImageView.<init>(ImageView.java:115) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  ... 26 more 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864): Caused by: java.lang.NullPointerException 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.graphics.drawable.RotateDrawable.inflate(RotateDrawable.java:207) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.graphics.drawable.Drawable.createFromXmlInner(Drawable.java:788) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.graphics.drawable.Drawable.createFromXml(Drawable.java:729) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  at android.content.res.Resources.loadDrawable(Resources.java:1690) 
10-28 12:10:50.765: ERROR/AndroidRuntime(1864):  ... 28 more 

Quelles sont les raisons pourrait-il y avoir pour cet échec sur API7? Mes ressources dessinables sont dans res/drawable (j'ai essayé de faire des copies dans/drawable, et le problème persiste indépendamment des dossiers drawable- {hdpi, ldpi}). Par souci d'exhaustivité, needle_green.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<rotate   xmlns:android="http://schemas.android.com/apk/res/android" 
       android:fromDegrees="90" 
       android:toDegrees="90" 
       android:pivotY="125" 
       android:drawable="@drawable/needle_base_green" /> 

Et needle_base_green:

<?xml version="1.0" encoding="UTF-8"?> 
<shape   xmlns:android="http://schemas.android.com/apk/res/android" 
       android:shape="line"> 
    <stroke  android:width="2dp" 
       android:color="#00ff00" /> 
</shape> 

C'est à peu près une première application Android, il est donc probablement quelque chose scandaleusement trivial. Merci pour toute aide.

+0

je dirais d'essayer de recréer ont éclipse les objets générés. "Menu Projet -> Nettoyer ..." puis sauvegardez un fichier java et il génèrera à nouveau les objets. voir si ça aide. –

+0

J'ai essayé cela plusieurs fois malheureusement :( – Estel

Répondre

1

Android ne peut pas trouver res/drawable/needle_green.xml. Avez-vous, si non nous montrer le code.

ajouté: Essayez d'utiliser # FFFF0000 (les deux premiers est alpha) en tant que valeur de couleur

+0

Il a donné nullpointererrors pour les deux en fonction de ce qui a été référencé en premier.Voici la version verte est identique à la version rouge (le _base_ version est similaire) Estel

+0

J'ai modifié ma réponse –

+0

Pas de chance, j'ai peur. Même erreur – Estel

0

Android ressemble dans res/drawable, pas dans res/drawables.

+0

Désolé, ce sont des fautes de frappe (toutes!) Dans mon message – Estel

Questions connexes