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

获取资源在android应用程序中未找到异常,android,android-source,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,

我正在尝试在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
任何帮助都将不胜感激

问候,,
Yuvi

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

因此,经过长时间的努力和谷歌搜索两天多之后,我发现了这个问题。apk中没有
可绘制hdpi
文件夹。我通过在Android.mk文件中添加
LOCAL\u AAPT\u标志+=-c mdpi、hdpi、xhdpi
行解决了这个问题

那些与同样问题作斗争的人遵循以下步骤:

检查它在哪一行给出错误:
Binary-XML文件行#11:膨胀类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" />

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

原因:android.content.res.Resources$NotFoundException:资源不是可绘制的(颜色或路径):类型值{t=0x1/d=0x7f02000d a=-1 r=0x7f02000d}

这里
r=0x7f02000d
是资源id,您可以在项目/gen/r.java中找到它 如果您在R.java中搜索
0x7f02000d
,您将能够找到造成问题的资源,在我的例子中是
R.drawable.ic\u back

希望它能帮助其他人解决他们的问题

问候,,
Yuvi

你试过清理和重建这个项目吗?@blackbelt已经做了很多次了。
<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" />