0

我正在尝试在 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-* 文件夹中,那么应用程序就会运行。但随后用户界面变得分散。

有没有人知道,问题可能是什么。我是否必须在 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.
========================

任何帮助将不胜感激。

问候, 尤维

4

2 回答 2

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,如果你在 R.java 中搜索,你可以在 yourproject/gen/R.java0x7f02000d中找到它,那么你将能够找到哪个资源造成了问题,在我的例子中是R.drawable.ic_back

希望它可以帮助其他人解决他们的问题。

问候, 尤维

于 2013-05-02T16:22:55.693 回答
0

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

于 2013-05-02T11:57:42.813 回答