Binary XML file line #2: Error inflating class

 自定义一个View,并在layout文件中进行部署,执行程序报以下错误:

 

[html]  view plain copy
  1. E/AndroidRuntime( 1292): FATAL EXCEPTION: main  
  2. E/AndroidRuntime( 1292): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.raycommtech/com.raycommtech.HomecloudActivity}: android.view.InflateException: Binary XML file line #2: Error inflating class android.widget.AbsoluteLayout  
  3. E/AndroidRuntime( 1292):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)  
  4. E/AndroidRuntime( 1292):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)  
  5. E/AndroidRuntime( 1292):    at android.app.ActivityThread.access$1500(ActivityThread.java:117)  
  6. E/AndroidRuntime( 1292):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)  
  7. E/AndroidRuntime( 1292):    at android.os.Handler.dispatchMessage(Handler.java:99)  
  8. E/AndroidRuntime( 1292):    at android.os.Looper.loop(Looper.java:130)  
  9. E/AndroidRuntime( 1292):    at android.app.ActivityThread.main(ActivityThread.java:3683)  
  10. E/AndroidRuntime( 1292):    at java.lang.reflect.Method.invokeNative(Native Method)  
  11. E/AndroidRuntime( 1292):    at java.lang.reflect.Method.invoke(Method.java:507)  
  12. E/AndroidRuntime( 1292):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)  
  13. E/AndroidRuntime( 1292):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)  
  14. E/AndroidRuntime( 1292):    at dalvik.system.NativeStart.main(Native Method)  
  15. E/AndroidRuntime( 1292): Caused by: android.view.InflateException: Binary XML file line #2: Error inflating class android.widget.AbsoluteLayout  
  16. E/AndroidRuntime( 1292):    at android.view.LayoutInflater.createView(LayoutInflater.java:518)  
  17. E/AndroidRuntime( 1292):    at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)  
  18. E/AndroidRuntime( 1292):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:568)  
  19. E/AndroidRuntime( 1292):    at android.view.LayoutInflater.inflate(LayoutInflater.java:386)  
  20. E/AndroidRuntime( 1292):    at android.view.LayoutInflater.inflate(LayoutInflater.java:320)  
  21. E/AndroidRuntime( 1292):    at android.view.LayoutInflater.inflate(LayoutInflater.java:276)  
  22. E/AndroidRuntime( 1292):    at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:207)  
  23. E/AndroidRuntime( 1292):    at android.app.Activity.setContentView(Activity.java:1657)  
  24. E/AndroidRuntime( 1292):    at com.raycommtech.HomecloudActivity.onCreate(HomecloudActivity.java:92)  
  25. E/AndroidRuntime( 1292):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)  
  26. E/AndroidRuntime( 1292):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)  
  27. E/AndroidRuntime( 1292):    ... 11 more  
  28. E/AndroidRuntime( 1292): Caused by: java.lang.reflect.InvocationTargetException  
  29. E/AndroidRuntime( 1292):    at java.lang.reflect.Constructor.constructNative(Native Method)  
  30. E/AndroidRuntime( 1292):    at java.lang.reflect.Constructor.newInstance(Constructor.java:415)  
  31. E/AndroidRuntime( 1292):    at android.view.LayoutInflater.createView(LayoutInflater.java:505)  
  32. E/AndroidRuntime( 1292):    ... 21 more  
  33. E/AndroidRuntime( 1292): Caused by: android.content.res.Resources$NotFoundException: Resource is not a Drawable (color or path): TypedValue{t=0x1/d=0x7f020020 a=-1 r=0x7f020020}  
  34. E/AndroidRuntime( 1292):    at android.content.res.Resources.loadDrawable(Resources.java:1681)  
  35. E/AndroidRuntime( 1292):    at android.content.res.TypedArray.getDrawable(TypedArray.java:601)  
  36. E/AndroidRuntime( 1292):    at android.view.View.<init>(View.java:1951)  
  37. E/AndroidRuntime( 1292):    at android.view.View.<init>(View.java:1899)  
  38. E/AndroidRuntime( 1292):    at android.view.ViewGroup.<init>(ViewGroup.java:286)  
  39. E/AndroidRuntime( 1292):    at android.widget.AbsoluteLayout.<init>(AbsoluteLayout.java:47)  
  40. E/AndroidRuntime( 1292):    ... 24 more  
开始以为是自定义的View重载的方法有问题,网上也查了很多关于自定义View方面引发的错误,还是木有得到解决。

 

       仔细看看错误,就是没有找到资源文件,看看res/下面的资源文件,全放在drawable-mdpi/目录下,突然灵光一现,怀疑寻找的位置资源文件不存在,于是将drawable-mdpi/下的资源文件拷贝一份到drawable-ldpi/目录下,还是报上面的错误,再拷贝一份到drawable-hdpi/目录下,问题解决。

       还有另外一种解决方法是在res/下建一目录drawable/,将drawable-mdpi/下所有的资源文件都拷贝到drawable/下即可

 

原文引用:http://blog.csdn.net/harry_helei/article/details/7265610

 

你可能感兴趣的:(binary)