来自可绘制资源ID的文件res / drawable / abc_ic_ab_back_material.xml#0x7f020016

时间:2016-03-02 06:08:52

标签: android android-gradle android-design-library

最近android support library已更新为23.2.0。下载android sdk并将android设计支持库更新为23.2.0后,此错误会重复发生。我的项目甚至无法编译。完整的错误日志说:

03-02 12:00:04.945 9324-9324/com.creditease.zhiwang.debug E/AndroidRuntime: FATAL EXCEPTION: main
        java.lang.RuntimeException: Unable to start activity ComponentInfo{com.creditease.zhiwang.debug/com.creditease.zhiwang.activity.TabContainerActivity}: android.content.res.Resources$NotFoundException: File res/drawable/abc_ic_ab_back_material.xml from drawable resource ID #0x7f020016
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2363)
        at android.app.ActivityThread.access$700(ActivityThread.java:169)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1330)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:137)
        at android.app.ActivityThread.main(ActivityThread.java:5528)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:525)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1209)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1025)
        at dalvik.system.NativeStart.main(Native Method)
        Caused by: android.content.res.Resources$NotFoundException: File res/drawable/abc_ic_ab_back_material.xml from drawable resource ID #0x7f020016
        at android.content.res.Resources.loadDrawable(Resources.java:2974)
        at android.content.res.Resources.getDrawable(Resources.java:1558)
        at android.support.v7.widget.TintResources.superGetDrawable(TintResources.java:48)
        at android.support.v7.widget.AppCompatDrawableManager.onDrawableLoadedFromResources(AppCompatDrawableManager.java:374)
        at android.support.v7.widget.TintResources.getDrawable(TintResources.java:44)
        at android.support.v4.content.ContextCompat.getDrawable(ContextCompat.java:323)
        at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:180)
        at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:173)
        at android.support.v7.widget.ToolbarWidgetWrapper.<init>(ToolbarWidgetWrapper.java:184)
        at android.support.v7.widget.ToolbarWidgetWrapper.<init>(ToolbarWidgetWrapper.java:91)
        at android.support.v7.app.ToolbarActionBar.<init>(ToolbarActionBar.java:74)
        at android.support.v7.app.AppCompatDelegateImplV7.setSupportActionBar(AppCompatDelegateImplV7.java:210)
        at android.support.v7.app.AppCompatActivity.setSupportActionBar(AppCompatActivity.java:119)
        at com.creditease.zhiwang.activity.BaseActivity.initToolBar(BaseActivity.java:300)
        at com.creditease.zhiwang.activity.BaseActivity.initToolBar(BaseActivity.java:265)
        at com.creditease.zhiwang.activity.TabContainerActivity.onCreate(TabContainerActivity.java:107)
        at android.app.Activity.performCreate(Activity.java:5372)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2271)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2363) 
        at android.app.ActivityThread.access$700(ActivityThread.java:169) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1330) 
        at android.os.Handler.dispatchMessage(Handler.java:99) 
        at android.os.Looper.loop(Looper.java:137) 
        at android.app.ActivityThread.main(ActivityThread.java:5528) 
        at java.lang.reflect.Method.invokeNative(Native Method) 
        at java.lang.reflect.Method.invoke(Method.java:525) 
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1209) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1025) 
        at dalvik.system.NativeStart.main(Native Method) 
        Caused by: org.xmlpull.v1.XmlPullParserException: Binary XML file line #17: invalid drawable tag vector
        at android.graphics.drawable.Drawable.createFromXmlInner(Drawable.java:933)
        at android.graphics.drawable.Drawable.createFromXml(Drawable.java:873)
        at android.content.res.Resources.loadDrawable(Resources.java:2970)
        at android.content.res.Resources.getDrawable(Resources.java:1558) 
        at android.support.v7.widget.TintResources.superGetDrawable(TintResources.java:48) 
        at android.support.v7.widget.AppCompatDrawableManager.onDrawableLoadedFromResources(AppCompatDrawableManager.java:374) 
        at android.support.v7.widget.TintResources.getDrawable(TintResources.java:44) 
        at android.support.v4.content.ContextCompat.getDrawable(ContextCompat.java:323) 
        at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:180) 
        at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:173) 
        at android.support.v7.widget.ToolbarWidgetWrapper.<init>(ToolbarWidgetWrapper.java:184) 
        at android.support.v7.widget.ToolbarWidgetWrapper.<init>(ToolbarWidgetWrapper.java:91) 
        at android.support.v7.app.ToolbarActionBar.<init>(ToolbarActionBar.java:74) 
        at android.support.v7.app.AppCompatDelegateImplV7.setSupportActionBar(AppCompatDelegateImplV7.java:210) 
        at android.support.v7.app.AppCompatActivity.setSupportActionBar(AppCompatActivity.java:119) 
        at com.creditease.zhiwang.activity.BaseActivity.initToolBar(BaseActivity.java:300) 
        at com.creditease.zhiwang.activity.BaseActivity.initToolBar(BaseActivity.java:265) 
        at com.creditease.zhiwang.activity.TabContainerActivity.onCreate(TabContainerActivity.java:107) 
        at android.app.Activity.performCreate(Activity.java:5372) 
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104) 
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2271) 
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2363) 
        at android.app.ActivityThread.access$700(ActivityThread.java:169) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1330) 
        at android.os.Handler.dispatchMessage(Handler.java:99) 
        at android.os.Looper.loop(Looper.java:137) 
        at android.app.ActivityThread.main(ActivityThread.java:5528) 
        at java.lang.reflect.Method.invokeNative(Native Method) 
        at java.lang.reflect.Method.invoke(Method.java:525) 
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1209) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1025) 
        at dalvik.system.NativeStart.main(Native Method)

setSupportActionBar(toolbar);引发了此错误,但23.0.1的{​​{1}}未发生此错误。同时根据这个日志,我猜测从android design library 23.2.0开始删除了这个drawable。

那么,有人能告诉我为什么会这样吗?

7 个答案:

答案 0 :(得分:43)

我认为您需要在gradle中进行更改。

// Gradle Plugin 2.0+  
 android {  
   defaultConfig {  
     vectorDrawables.useSupportLibrary = true  
    }  
 }  

您会注意到此新属性仅存在于Gradle插件的2.0版本中。如果您使用的是Gradle 1.5,则可以使用

// Gradle Plugin 1.5  
 android {  
   defaultConfig {  
     // Stops the Gradle plugin's automatic rasterization of vectors
     generatedDensities = []  
  }  
  // Flag to tell aapt to keep the attribute ids around
  // This is handled for you by the 2.0+ Gradle Plugin  
  aaptOptions {  
    additionalParameters "--no-version-vectors"  
  }  
 }  

我发现了类似的问题here

请参阅Android支持库更新中的Support Vector Drawables and Animated Vector Drawables。 我希望它可以帮到你。

答案 1 :(得分:10)

根据Google 24.0.0支持库的文档,他们已将矢量可绘制库更改为之前的版本: 添加了AppCompatDelegate.setCompatVectorFromResourcesEnabled()方法,以便在运行Android 4.4(API级别19)及更低版本的设备上重新启用DrawableContainer个对象中矢量绘图的使用。请参阅AppCompat v23.2 - Age of the vectors!了解更多信息。

我面临同样的问题,我的项目中使用的SVG statelist drawables在Marshmallow设备上工作得很好。

后来当我在Android N中遇到同样的崩溃时,我意识到svgs有点损坏并包含如下字符: 这导致了崩溃。

但这些并没有反映在Android Marshmallow和之前的设备中。

确保您的vector drawable不包含任何这些字符,因为解析方式已从库24.0.0更改。所以矢量drawables工作正常,直到棉花糖可能无法在Nougat设备中工作。

希望这会有所帮助:)

答案 2 :(得分:6)

我通过从

更新我的支持库来解决此问题

'com.android.support:appcompat-v7:23.2.0'
'com.android.support:design:23.2.0'

23.2.1的相同依赖关系。

当我遇到问题时,我没有对Android Studio构建的模块进行任何更改。

所以我很困惑然后我尝试更新android支持库。 更新后,请记住更新您的build.gradle

答案 3 :(得分:5)

我解决了以下问题: 尝试将styles.xml更改为

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>

这是因为如果样式需要ActionBar,则有可能找不到abc_back按钮但没有操作栏问题就解决了

答案 4 :(得分:2)

这对我有用:将build.gradle中的compile 'com.android.support:design:24.0.0-alpha1'版本替换为有效的compile 'com.android.support:design:23.2.1'版本。通过在Android Studio中从头开始创建新项目并使用其中的版本来查找哪个版本。

当我从文件 - &gt; - &gt; 活动菜单添加导航抽屉活动时,我遇到了这个问题使用Android Studio进行项目。

Android Studio添加了依赖项,如下所示: {{1}} (我不确定确切的版本,但它有'24'和'alpha')。

然后我创建了一个新的虚拟项目,在新项目向导中指定了导航抽屉活动。我注意到新项目有不同的依赖关系:{{1}}

所以我把这个依赖项放在第一个项目中,问题就解决了。

答案 5 :(得分:1)

来源 - http://android-developers.blogspot.in/2016/02/android-support-library-232.html

  

将AppCompat与ImageView(或ImageButton等子类)一起使用时   和FloatingActionButton),你将能够使用新的应用程序:srcCompat   属性引用向量drawables(以及任何其他drawable)   可用于android:src):

<ImageView  
  android:layout_width="wrap_content"  
  android:layout_height="wrap_content"  
  app:srcCompat="@drawable/ic_add" />  

您可以在根元素中将应用定义为

的xmlns:应用= “http://schemas.android.com/apk/res-auto”

答案 6 :(得分:0)

我有这个问题,因为我的清单文件的样式仅以v21样式定义。不知道为什么它指向这种类型的错误,但有人可能会发现这有用。