在Android应用程序中获取资源未找到异常

时间:2013-05-02 11:43:42

标签: android android-source

我正在尝试在AOSP中构建一个应用程序,我的开发工具包具有HDPI密度,我已使用以下代码片段对其进行了双重验证:

switch (getResources().getDisplayMetrics().densityDpi) {
case DisplayMetrics.DENSITY_LOW:
    Log.d(TAG, "\n\n\n\n LDPI \n\n\n\n");
    break;
case DisplayMetrics.DENSITY_MEDIUM:
    Log.d(TAG, "\n\n\n\n MDPI \n\n\n\n");
    break;
case DisplayMetrics.DENSITY_HIGH:
    Log.d(TAG, "\n\n\n\n HDPI \n\n\n\n");
    // ...
    break;
case DisplayMetrics.DENSITY_XHIGH:
    Log.d(TAG, "\n\n\n\n XDPI \n\n\n\n");
    // ...
    break;
}

当我在Android文件系统中构建我的应用程序时,如果我运行它,那么我会收到以下错误:

E/AndroidRuntime(  825): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example/com.example.MainActivity}: android.view.InflateException: Binary XML file line #11: Error inflating class android.widget.Button
E/AndroidRuntime(  825):        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956)
E/AndroidRuntime(  825):        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
E/AndroidRuntime(  825):        at android.app.ActivityThread.access$600(ActivityThread.java:123)
E/AndroidRuntime(  825):        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
E/AndroidRuntime(  825):        at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(  825):        at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime(  825):        at android.app.ActivityThread.main(ActivityThread.java:4424)
E/AndroidRuntime(  825):        at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(  825):        at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime(  825):        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
E/AndroidRuntime(  825):        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
E/AndroidRuntime(  825):        at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime(  825): Caused by: android.view.InflateException: Binary XML file line #11: Error inflating class android.widget.Button
E/AndroidRuntime(  825):        at android.view.LayoutInflater.createView(LayoutInflater.java:606)
E/AndroidRuntime(  825):        at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.onCreateView(LayoutInflater.java:653)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:678)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.rInflate(LayoutInflater.java:739)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.rInflate(LayoutInflater.java:742)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.parseInclude(LayoutInflater.java:823)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.rInflate(LayoutInflater.java:729)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.rInflate(LayoutInflater.java:742)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.rInflate(LayoutInflater.java:742)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.inflate(LayoutInflater.java:489)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
E/AndroidRuntime(  825):        at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:251)
E/AndroidRuntime(  825):        at android.app.Activity.setContentView(Activity.java:1835)
E/AndroidRuntime(  825):        at com.example.MainActivity.onCreate(MainActivity.java:96)
E/AndroidRuntime(  825):        at android.app.Activity.performCreate(Activity.java:4465)
E/AndroidRuntime(  825):        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
E/AndroidRuntime(  825):        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
E/AndroidRuntime(  825):        ... 11 more
E/AndroidRuntime(  825): Caused by: java.lang.reflect.InvocationTargetException
E/AndroidRuntime(  825):        at java.lang.reflect.Constructor.constructNative(Native Method)
E/AndroidRuntime(  825):        at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
E/AndroidRuntime(  825):        at android.view.LayoutInflater.createView(LayoutInflater.java:586)
E/AndroidRuntime(  825):        ... 29 more
E/AndroidRuntime(  825): Caused by: android.content.res.Resources$NotFoundException: Resource is not a Drawable (color or path): TypedValue{t=0x1/d=0x7f02000d a=-1 r=0x7f02000d}
E/AndroidRuntime(  825):        at android.content.res.Resources.loadDrawable(Resources.java:1897)
E/AndroidRuntime(  825):        at android.content.res.TypedArray.getDrawable(TypedArray.java:601)
E/AndroidRuntime(  825):        at android.widget.TextView.<init>(TextView.java:620)
E/AndroidRuntime(  825):        at android.widget.Button.<init>(Button.java:108)
E/AndroidRuntime(  825):        at android.widget.Button.<init>(Button.java:104)
E/AndroidRuntime(  825):        ... 32 more

我的所有可绘制资源都是drawable-hdpi。

但是如果我把drawables放在所有drawable- *文件夹中,那么app会运行。 但随后UI变得分散。

有没有人知道,问题可能是什么。我是否必须在Android.mk中添加任何变量或标志

=========edit=========
The app works fine if I build with eclipse. And run on the same device.
Therefore issue might be in building app along with AOSP.
========================

任何帮助都将受到高度赞赏。

此致 Yuvi

2 个答案:

答案 0 :(得分:1)

所以经过长时间的挣扎和谷歌搜索超过两天后,我发现了这个问题。 apk中没有drawable-hdpi文件夹。我已在LOCAL_AAPT_FLAGS += -c mdpi,hdpi,xhdpi文件中添加Android.mk行解决了该问题。

那些正在努力解决同样问题的人遵循这些晚餐步骤:

检查它出错的行: Binary XML file line #11: Error inflating class android.widget.Button

在我的xml文件中,它是:

<Button
    android:id="@+id/btn_footer_back"
    style="@style/normalButtonStyle"
    android:layout_width="wrap_content"
    android:layout_height="60px"
    android:layout_marginRight="1dp"
    android:background="@drawable/button_state_selector"
    android:drawableLeft="@drawable/ic_back"
    android:drawablePadding="10px"
    android:text="@string/back"
    android:visibility="gone" />

那么,现在下一步是什么,日志本身讲述了这个故事,检查一下:

Caused by: android.content.res.Resources$NotFoundException: Resource is not a Drawable (color or path): TypedValue{t=0x1/d=0x7f02000d a=-1 r=0x7f02000d}

此处r=0x7f02000d是资源ID,您可以在project / gen / R.java中找到它 如果您在R.java中搜索0x7f02000d,那么您将能够找到创建问题的资源,在我的情况下是R.drawable.ic_back

希望有助于其他人解决他们的问题。

此致 Yuvi

答案 1 :(得分:0)

您的用户界面分散,因为在设备上显示时,您的文件与适当的密度或分辨率不匹配。您应该在xml中使用与密度无关的像素。 并创建Drawable文件夹并将文件放入其中。并提供drawable文件夹的参考。