2012-08-07 1 views
3

J'ai examiné un tas de problèmes et d'explications, et rien ne fonctionne pour moi. La toute première activité de mon programme, qui est une ListActivity, a du mal à gonfler son fichier xml. La sortie LogCat est:Erreur de gonflement de la classe android.widget.listview

08-01 08:36:17.800: E/AndroidRuntime(1935): FATAL EXCEPTION: main 
08-01 08:36:17.800: E/AndroidRuntime(1935): java.lang.RuntimeException: Unable to start activity ComponentInfo{jamie.basketball.gui/jamie.basketball.gui.TeamDisplayActivity}: android.view.InflateException: Binary XML file line #15: Error inflating class android.widget.ListView 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.os.Handler.dispatchMessage(Handler.java:99) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.os.Looper.loop(Looper.java:123) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.app.ActivityThread.main(ActivityThread.java:3683) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at java.lang.reflect.Method.invokeNative(Native Method) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at java.lang.reflect.Method.invoke(Method.java:507) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at dalvik.system.NativeStart.main(Native Method) 
08-01 08:36:17.800: E/AndroidRuntime(1935): Caused by: android.view.InflateException: Binary XML file line #15: Error inflating class android.widget.ListView 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.view.LayoutInflater.createView(LayoutInflater.java:518) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:568) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.view.LayoutInflater.rInflate(LayoutInflater.java:623) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.view.LayoutInflater.inflate(LayoutInflater.java:408) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.view.LayoutInflater.inflate(LayoutInflater.java:320) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.view.LayoutInflater.inflate(LayoutInflater.java:276) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:207) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.app.Activity.setContentView(Activity.java:1657) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at jamie.basketball.gui.TeamDisplayActivity.onCreate(TeamDisplayActivity.java:137) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  ... 11 more 
08-01 08:36:17.800: E/AndroidRuntime(1935): Caused by: java.lang.reflect.InvocationTargetException 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at java.lang.reflect.Constructor.constructNative(Native Method) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at java.lang.reflect.Constructor.newInstance(Constructor.java:415) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.view.LayoutInflater.createView(LayoutInflater.java:505) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  ... 22 more 
08-01 08:36:17.800: E/AndroidRuntime(1935): Caused by: java.lang.NullPointerException 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at  android.content.res.AssetManager.getResourceTextArray(AssetManager.java:214) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.content.res.Resources.getTextArray(Resources.java:361) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.content.res.TypedArray.getTextArray(TypedArray.java:628) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.widget.ListView.<init>(ListView.java:168) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  at android.widget.ListView.<init>(ListView.java:159) 
08-01 08:36:17.800: E/AndroidRuntime(1935):  ... 25 more 

Je ne suis pas entièrement sûr de ce qui se passe. J'ai vérifié dans le manifeste Android, et la ligne 15 est <application, ce qui ne semble pas être un problème. Et la ligne 15 de mon fichier XML est juste <ListView. Je poste tout le fichier XML au cas où il y aurait quelque chose d'autre qui semble être le problème.

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
     xmlns:tools="http://schemas.android.com/tools" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" > 

     <TextView 
      android:id="@+id/num_of_teams" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_alignParentTop="true" 
      android:layout_centerHorizontal="true" 
      android:text="@string/debug" 
      android:textAppearance="?android:attr/textAppearanceLarge" /> 

     <ListView 
      android:id="@+id/@android:id/list" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_below="@+id/num_of_teams" 
      android:layout_marginTop="5dp" 
      android:entries="@layout/team_list_entry" > 

     </ListView> 

     <Button 
      android:id="@+id/delete_team" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_below="@+id/@android:id/list" 
      android:layout_marginLeft="20dp" 
      android:layout_marginTop="30dp" 
      android:text="@string/delete_team" /> 

     <Button 
      android:id="@+id/add_team" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_alignParentLeft="false" 
      android:layout_alignParentTop="false" 
      android:layout_below="@+id/@android:id/list" 
      android:layout_marginLeft="50dp" 
      android:layout_marginTop="30dp" 
      android:layout_toRightOf="@id/delete_team" 
      android:text="@string/add_team" /> 

    </RelativeLayout> 

En outre, pour l'enregistrement, la stacktrace qui fait référence à la ligne 137 de TeamDisplayActivity est juste setContentView(R.layout.team_list_display). Toute aide serait merveilleuse, je ne sais vraiment pas ce qui ne va pas. Merci à l'avance

+0

Postez aussi votre code. Votre classe 'PhoneLayoutInflater'. – 0gravity

+0

Ce n'est pas ma classe, c'est une partie de la bibliothèque Android ... –

+0

cliquez sur la ligne dans logcat: Celle qui a votre nom de fichier dessus et voyez dans quelle ligne il vous faut. –

Répondre

3

Cette ligne ne semble pas correcte:

android:entries="@layout/team_list_entry" 

Habituellement, je pense qu'il est spécifié comme

android:entries="@array/servers" etc. 

Et essayez de spécifier id comme:

android:id="@+id/list" 
+0

Normalement, je ne m'attendrais pas à voir team_entry_list défini à cet endroit. –

+0

Oups, n'a pas vu votre modification. Merci –

1

Vous utilisez @+id/@android:id/list

Je pense qu'il doit être @+id/android:list ou @+id/list

Vous pouvez voir ici: https://stackoverflow.com/a/4355644/617801

+0

Donne le même accident exact. J'ai le '@ + id/@ android: id/list' directement à partir du site Web SDK: http://developer.android.com/reference/android/app/ListActivity.html _votre propre vue DOIT contenir un objet ListView avec l'id "@ android: id/list" _ –

+0

cela signifie que vous devez utiliser: android: id = "@ android: id/list" pour votre listeVoir –

+0

Vous avez raison, mais ce n'était pas le problème, et n'a pas semble créer des problèmes –

0

android: id = "@ + id/@ android: id/liste" changer ceci dans android: id = » @ + id/list1" . Votre problème d'exception de gonflement binaire sera résolu. Et n'essayez jamais d'utiliser android: id = "@ + id/list" dans ListView. En utilisant une option de plus, vous pouvez créer votre ListView i.e android: id = "@ id/android: liste".

0

J'ai eu un problème similaire peut-être que cela aide quelqu'un d'autre. J'ai accidentellement mis android:onClick="onClickExamplesMethod" dans le ListView. Après avoir enlevé cela, il a travaillé à nouveau.

Questions connexes