最近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。
那么,有人能告诉我为什么会这样吗?
答案 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样式定义。不知道为什么它指向这种类型的错误,但有人可能会发现这有用。