在 API 19 上渲染矢量资产时 Android 应用程序崩溃在 API 20 以上运行良好

Posted

技术标签:

【中文标题】在 API 19 上渲染矢量资产时 Android 应用程序崩溃在 API 20 以上运行良好【英文标题】:Android App Crashes while rendering vector asset on API 19 works fine on API above 20 【发布时间】:2018-07-04 18:06:34 【问题描述】:

android API 级别 19 上使用以下代码和堆栈跟踪启动 MyActivity 时应用程序崩溃。 这适用于 Android API 级别 21 及更高版本。

矢量资源:ic_warning_white_24px.xml

activity_my.xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.NestedScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_
    android:layout_
    android:padding="8dp"
    tools:context="MyActivity">

    <LinearLayout
        android:layout_
        android:layout_
        android:orientation="vertical">

        <android.support.design.widget.TextInputLayout
            android:id="@+id/inputLayout"
            android:layout_
            android:layout_
            android:layout_marginBottom="16dp">

            <EditText
                android:id="@+id/editText"
                android:layout_
                android:layout_
                android:hint="Hint" />

        </android.support.design.widget.TextInputLayout>

        <android.support.v7.widget.AppCompatButton
            android:layout_
            android:layout_
            android:background="@color/colorAccent"
            android:drawableEnd="@drawable/ic_warning_white_24px"
            android:drawableRight="@drawable/ic_warning_white_24px"
            android:gravity="start|center_vertical"
            android:paddingLeft="16dp"
            android:paddingRight="16dp"
            android:text="Button"
            android:textColor="@color/white" />

    </LinearLayout>
</android.support.v4.widget.NestedScrollView>

MyActivity.java

public class MyActivity extends AppCompatActivity 

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_my);
    

还在我的 build.gradle

中添加了以下内容
defaultConfig 
    vectorDrawables.useSupportLibrary = true

堆栈跟踪:

进程:MyPackage,PID:16398 java.lang.RuntimeException:无法 开始活动 ComponentInfoMyPackage/MyActivity: android.view.InflateException:二进制 XML 文件第 0 行:错误 膨胀类 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2184) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233) 在 android.app.ActivityThread.access$800(ActivityThread.java:135) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:136) 在 android.app.ActivityThread.main(ActivityThread.java:5001) 在 java.lang.reflect.Method.invokeNative(Native Method) 在 java.lang.reflect.Method.invoke(Method.java:515) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) 在 dalvik.system.NativeStart.main(Native Method) 原因: android.view.InflateException:二进制 XML 文件第 0 行:错误 膨胀类 android.view.LayoutInflater.createView(LayoutInflater.java:620) 在 android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:696) 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:755) 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:758) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:492) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:397) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:353) 在 android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:287) 在 android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:139) 在 MyActivity.onCreate(MyActivity.java:43) 在 android.app.Activity.performCreate(Activity.java:5231) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2148) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233) 在 android.app.ActivityThread.access$800(ActivityThread.java:135) android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 在 android.os.Handler.dispatchMessage(Handler.java:102) android.os.Looper.loop(Looper.java:136) 在 android.app.ActivityThread.main(ActivityThread.java:5001) 在 java.lang.reflect.Method.invokeNative(Native Method) 位于 java.lang.reflect.Method.invoke(Method.java:515) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) dalvik.system.NativeStart.main(Native Method) 原因: java.lang.reflect.InvocationTargetException 在 java.lang.reflect.Constructor.constructNative(Native Method) 在 java.lang.reflect.Constructor.newInstance(Constructor.java:423) 在 android.view.LayoutInflater.createView(LayoutInflater.java:594) 在 android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:696) 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:755) android.view.LayoutInflater.rInflate(LayoutInflater.java:758) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:492) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:397) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:353) 在 android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:287) 在 android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:139) 在 MyActivity.onCreate(MyActivity.java:43) android.app.Activity.performCreate(Activity.java:5231) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2148) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233) 在 android.app.ActivityThread.access$800(ActivityThread.java:135) android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 在 android.os.Handler.dispatchMessage(Handler.java:102) android.os.Looper.loop(Looper.java:136) 在 android.app.ActivityThread.main(ActivityThread.java:5001) 在 java.lang.reflect.Method.invokeNative(Native Method) 位于 java.lang.reflect.Method.invoke(Method.java:515) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) dalvik.system.NativeStart.main(Native Method) 原因: android.content.res.Resources$NotFoundException:文件 res/drawable/ic_warning_white_24px.xml 来自可绘制资源 ID

0x7f080172 在 android.content.res.Resources.loadDrawable(Resources.java:2096) 在

android.content.res.TypedArray.getDrawable(TypedArray.java:602) 在 android.widget.TextView.(TextView.java:814) 在 android.widget.Button.(Button.java:107) 在 android.support.v7.widget.AppCompatButton.(AppCompatButton.java:71) 在 android.support.v7.widget.AppCompatButton.(AppCompatButton.java:67) 在 java.lang.reflect.Constructor.constructNative(Native Method) java.lang.reflect.Constructor.newInstance(Constructor.java:423) 在 android.view.LayoutInflater.createView(LayoutInflater.java:594) 在 android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:696) 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:755) android.view.LayoutInflater.rInflate(LayoutInflater.java:758) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:492) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:397) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:353) 在 android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:287) 在 android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:139) 在 MyActivity.onCreate(MyActivity.java:43) android.app.Activity.performCreate(Activity.java:5231) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2148) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233) 在 android.app.ActivityThread.access$800(ActivityThread.java:135) android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 在 android.os.Handler.dispatchMessage(Handler.java:102) android.os.Looper.loop(Looper.java:136) 在 android.app.ActivityThread.main(ActivityThread.java:5001) 在 java.lang.reflect.Method.invokeNative(Native Method) 位于 java.lang.reflect.Method.invoke(Method.java:515) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) dalvik.system.NativeStart.main(Native Method) 原因: org.xmlpull.v1.XmlPullParserException:二进制 XML 文件第 0 行: 无效的可绘制标签矢量 android.graphics.drawable.Drawable.createFromXmlInner(Drawable.java:933) 在 android.graphics.drawable.Drawable.createFromXml(Drawable.java:877) 在 android.content.res.Resources.loadDrawable(Resources.java:2092) 在 android.content.res.TypedArray.getDrawable(TypedArray.java:602) 在 android.widget.TextView.(TextView.java:814) 位于 android.widget.Button.(Button.java:107) 位于 android.support.v7.widget.AppCompatButton.(AppCompatButton.java:71) 在 android.support.v7.widget.AppCompatButton.(AppCompatButton.java:67) 在 java.lang.reflect.Constructor.constructNative(Native Method) java.lang.reflect.Constructor.newInstance(Constructor.java:423) 在 android.view.LayoutInflater.createView(LayoutInflater.java:594) 在 android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:696) 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:755) android.view.LayoutInflater.rInflate(LayoutInflater.java:758) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:492) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:397) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:353) 在 android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:287) 在 android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:139) 在 MyActivity.onCreate(MyActivity.java:43) android.app.Activity.performCreate(Activity.java:5231) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2148) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233) 在 android.app.ActivityThread.access$800(ActivityThread.java:135) android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 在 android.os.Handler.dispatchMessage(Handler.java:102) android.os.Looper.loop(Looper.java:136) 在 android.app.ActivityThread.main(ActivityThread.java:5001) 在 java.lang.reflect.Method.invokeNative(Native Method) 位于 java.lang.reflect.Method.invoke(Method.java:515) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) dalvik.system.NativeStart.main(Native Method)

也尝试了一些东西

static

    AppCompatDelegate.setCompatVectorFromResourcesEnabled(true);

.

public class MyActivity extends AppCompatActivity 

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        AppCompatDelegate.setCompatVectorFromResourcesEnabled(true);
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_my);
    

【问题讨论】:

【参考方案1】:

drawableLeft, drawableRight 不能使用矢量绘图。对不起。

也试试

        app:drawableEnd="@drawable/ic_warning_white_24px"
        app:drawableRight="@drawable/ic_warning_white_24px"

而不是

        android:drawableEnd="@drawable/ic_warning_white_24px"
        android:drawableRight="@drawable/ic_warning_white_24px"

(应用程序与安卓)

如果AppCompatButton已经实现了,你就可以这样使用了。

看到这个问题Is it possible to use VectorDrawable in Buttons and TextViews using android:DrawableRight?

查看这篇关于向量的精彩文章AppCompat — Age of the vectors

【讨论】:

获取错误:错误:属性 mypackage:drawableEnd' 未找到。 这意味着AppCompatButton还没有实现它。所以你必须在我链接的问题中找到可接受的解决方法。【参考方案2】:

我遇到了同样的问题。

我的解决方案是将AppCompatDelegate.setCompatVectorFromResourcesEnabled(true); 添加到

1) 应用创建方法(如果你有的话)

public class TestApplication extends Application 
    @Override
    public void onCreate() 
        super.onCreate();
        AppCompatDelegate.setCompatVectorFromResourcesEnabled(true);
    

2) 给你具体的活动onCreate():

public class TestActivity extends Activity 
    @Override
    public void onCreate() 
        super.onCreate();
        AppCompatDelegate.setCompatVectorFromResourcesEnabled(true);
    

【讨论】:

以上是关于在 API 19 上渲染矢量资产时 Android 应用程序崩溃在 API 20 以上运行良好的主要内容,如果未能解决你的问题,请参考以下文章

无法在Android Studio上更改API级别

在 android 中扩展 google map api v2 的离线矢量 TileProvider

无法在 Android Studio 上更改 API 级别

带有矢量资产图标的 android 谷歌地图中的自定义标记

在Android 4.x中显示矢量图形

带有 PDF 矢量图像的资产目录不会为 iOS 导出 @3x 分辨率