2016-03-03 4 views
12

Когда я включаю

vectorDrawables.useSupportLibrary = true 

Я получаю много resourceNotFoundExceptions на KitKat и ниже устройств. Я получаю это для NavigationView для меню, а также для ImageViews с приложением: srcCompat

android.content.res.Resources$NotFoundException: Resource ID #0x7f02006b 
at android.content.res.Resources.getValue(Resources.java:2305) 
at android.support.v7.widget.AppCompatDrawableManager.loadDrawableFromDelegates(AppCompatDrawableManager.java:268) 
at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:178) 
at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:173) 
at android.support.v7.view.menu.MenuItemImpl.getIcon(MenuItemImpl.java:421) 
at android.support.v7.view.menu.ActionMenuItemView.initialize(ActionMenuItemView.java:114) 
at android.support.v7.widget.ActionMenuPresenter.bindItemView(ActionMenuPresenter.java:206) 
at android.support.v7.view.menu.BaseMenuPresenter.getItemView(BaseMenuPresenter.java:182) 
at android.support.v7.widget.ActionMenuPresenter.getItemView(ActionMenuPresenter.java:192) 
at android.support.v7.widget.ActionMenuPresenter.flagActionItems(ActionMenuPresenter.java:480) 
at android.support.v7.view.menu.MenuBuilder.flagActionItems(MenuBuilder.java:1138) 
at android.support.v7.view.menu.BaseMenuPresenter.updateMenuView(BaseMenuPresenter.java:91) 
at android.support.v7.widget.ActionMenuPresenter.updateMenuView(ActionMenuPresenter.java:229) 
at android.support.v7.view.menu.MenuBuilder.dispatchPresenterUpdate(MenuBuilder.java:284) 
at android.support.v7.view.menu.MenuBuilder.onItemsChanged(MenuBuilder.java:1030) 
at android.support.v7.view.menu.MenuBuilder.startDispatchingItemsChanged(MenuBuilder.java:1053) 
at android.support.v7.app.AppCompatDelegateImplV7.preparePanel(AppCompatDelegateImplV7.java:1345) 
at android.support.v7.app.AppCompatDelegateImplV7.doInvalidatePanelMenu(AppCompatDelegateImplV7.java:1583) 
at android.support.v7.app.AppCompatDelegateImplV7.access$100(AppCompatDelegateImplV7.java:89) 
at android.support.v7.app.AppCompatDelegateImplV7$1.run(AppCompatDelegateImplV7.java:128) 
at android.os.Handler.handleCallback(Handler.java:733) 
at android.os.Handler.dispatchMessage(Handler.java:95) 
at android.os.Looper.loop(Looper.java:146) 
at android.app.ActivityThread.main(ActivityThread.java:5653) 
at java.lang.reflect.Method.invokeNative(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:515) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:110) 

для NavigationView

Process: org.ligi.gobandroid_hd, PID: 11473 
java.lang.RuntimeException: Unable to start activity ComponentInfo{org.ligi.gobandroid_hd/org.ligi.gobandroid_hd.ui.game_setup.GoSetupActivity}: android.view.InflateException: Binary XML file line #20: Error inflating class android.support.design.widget.NavigationView 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2404) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2464) 
    at android.app.ActivityThread.access$900(ActivityThread.java:172) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1308) 
    at android.os.Handler.dispatchMessage(Handler.java:102) 
    at android.os.Looper.loop(Looper.java:146) 
    at android.app.ActivityThread.main(ActivityThread.java:5653) 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:515) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107) 
    at dalvik.system.NativeStart.main(Native Method) 
Caused by: android.view.InflateException: Binary XML file line #20: Error inflating class android.support.design.widget.NavigationView 
    at android.view.LayoutInflater.createView(LayoutInflater.java:626) 
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:702) 
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:761) 
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:769) 
    at android.view.LayoutInflater.inflate(LayoutInflater.java:498) 
    at android.view.LayoutInflater.inflate(LayoutInflater.java:398) 
    at android.view.LayoutInflater.inflate(LayoutInflater.java:354) 
    at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:267) 
    at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:129) 
    at org.ligi.gobandroid_hd.ui.application.GobandroidFragmentActivity.setContentView(GobandroidFragmentActivity.java:85) 
    at org.ligi.gobandroid_hd.ui.GoActivity.onCreate(GoActivity.java:108) 
    at android.app.Activity.performCreate(Activity.java:5541) 
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093) 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2368) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2464)  
    at android.app.ActivityThread.access$900(ActivityThread.java:172)  
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1308)  
    at android.os.Handler.dispatchMessage(Handler.java:102)  
    at android.os.Looper.loop(Looper.java:146)  
    at android.app.ActivityThread.main(ActivityThread.java:5653)  
    at java.lang.reflect.Method.invokeNative(Native Method)  
    at java.lang.reflect.Method.invoke(Method.java:515)  
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)  
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)  
    at dalvik.system.NativeStart.main(Native Method)  
Caused by: java.lang.reflect.InvocationTargetException 
    at java.lang.reflect.Constructor.constructNative(Native Method) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423) 
    at android.view.LayoutInflater.createView(LayoutInflater.java:600) 
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:702)  
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:761)  
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:769)  
    at android.view.LayoutInflater.inflate(LayoutInflater.java:498)  
    at android.view.LayoutInflater.inflate(LayoutInflater.java:398)  
    at android.view.LayoutInflater.inflate(LayoutInflater.java:354)  
    at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:267)  
    at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:129)  
    at org.ligi.gobandroid_hd.ui.application.GobandroidFragmentActivity.setContentView(GobandroidFragmentActivity.java:85)  
    at org.ligi.gobandroid_hd.ui.GoActivity.onCreate(GoActivity.java:108)  
    at android.app.Activity.performCreate(Activity.java:5541)  
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093)  
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2368)  
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2464)  
    at android.app.ActivityThread.access$900(ActivityThread.java:172)  
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1308)  
    at android.os.Handler.dispatchMessage(Handler.java:102)  
    at android.os.Looper.loop(Looper.java:146)  
    at android.app.ActivityThread.main(ActivityThread.java:5653)  
    at java.lang.reflect.Method.invokeNative(Native Method)  
    at java.lang.reflect.Method.invoke(Method.java:515)  
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)  
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)  
    at dalvik.system.NativeStart.main(Native Method)  
Caused by: android.content.res.Resources$NotFoundException: Resource ID #0x7f020067 
    at android.content.res.Resources.getValue(Resources.java:2305) 
    at android.support.v7.widget.AppCompatDrawableManager.loadDrawableFromDelegates(AppCompatDrawableManager.java:268) 
    at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:178) 
    at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:173) 
    at android.support.v7.view.menu.MenuItemImpl.getIcon(MenuItemImpl.java:421) 
    at android.support.design.internal.NavigationMenuPresenter$NavigationMenuAdapter.prepareMenuItems(NavigationMenuPresenter.java:475) 
    at android.support.design.internal.NavigationMenuPresenter$NavigationMenuAdapter.update(NavigationMenuPresenter.java:436) 
    at android.support.design.internal.NavigationMenuPresenter.updateMenuView(NavigationMenuPresenter.java:112) 
    at android.support.design.widget.NavigationView.inflateMenu(NavigationView.java:241) 
    at android.support.design.widget.NavigationView.<init>(NavigationView.java:169) 
    at android.support.design.widget.NavigationView.<init>(NavigationView.java:95) 
    at java.lang.reflect.Constructor.constructNative(Native Method)  
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)  
    at android.view.LayoutInflater.createView(LayoutInflater.java:600)  
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:702)  
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:761)  
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:769)  
    at android.view.LayoutInflater.inflate(LayoutInflater.java:498)  
    at android.view.LayoutInflater.inflate(LayoutInflater.java:398)  
    at android.view.LayoutInflater.inflate(LayoutInflater.java:354)  
    at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:267)  
    at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:129)  
    at org.ligi.gobandroid_hd.ui.application.GobandroidFragmentActivity.setContentView(GobandroidFragmentActivity.java:85)  
    at org.ligi.gobandroid_hd.ui.GoActivity.onCreate(GoActivity.java:108)  
    at android.app.Activity.performCreate(Activity.java:5541)  
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093)  
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2368)  
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2464)  
    at android.app.ActivityThread.access$900(ActivityThread.java:172)  
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1308)  
    at android.os.Handler.dispatchMessage(Handler.java:102)  
    at android.os.Looper.loop(Looper.java:146)  
    at android.app.ActivityThread.main(ActivityThread.java:5653)  
    at java.lang.reflect.Method.invokeNative(Native Method)  
    at java.lang.reflect.Method.invoke(Method.java:515)  
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)  
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)  
    at dalvik.system.NativeStart.main(Native Method)  
+0

Какова ваша версия в градиенте? – Sayem

+1

Вы используете библиотеку поддержки v23.2.0? и ваш build.gradle имеет модификации, предложенные документами (и их можно найти в этом ответе: http://stackoverflow.com/a/35624744/4860513)? – W0rmH0le

+0

2.11 и build-plugin 2.0.0-beta6 – ligi

ответ

20

Я нашел проблему: У меня был мой вектор-вводимый коэффициент в вытяжке-anydpi/- это производит этот сбой - когда я переместить вводимый коэффициент к вытяжке/она работает отлично

+0

Thank вы! Это реальный ответ. –

+0

Один час, потраченный на решение этой проблемы # ° $% & £ § ... – Massimo

+2

Спасибо, переходя от 'drawable' к' drawable-nodpi', работал для меня. –

4

, насколько я читал на документы есть только доступ к XML для ImageView.

Для меню вы должны будете использовать в java.

toolbar.inflateMenu(menuResId); 
toolbar.getMenu() 
     .findItem(menuItemId) 
     .setIcon(VectorDrawableCompat 
         .createFromResource(resource, drawableId); 
+0

Я также ничего не видел в документах, но поскольку это в основном используется appcompat, мне было интересно, есть ли какой-то автоматизм под капотом, о котором я не знаю - элементы меню - большой прецедент для VectorDrawables - добавление этого обходного решения делает код уродливым – ligi

+0

hm - @chrisbanes заявляет в комментариях своего блога-сообщения «Элементы меню работают нормально. вы пытаетесь использовать его с предпочтениями? " – ligi

+0

Мне не нужно было добавлять это, и мои пункты меню просто работали из коробки без изменения XML. Я использую 23.0.4 библиотеки поддержки. –

5

Я был в состоянии использовать вектор на вводимый коэффициент предварительно Lollipop устройств путем обертывания их в StateListDrawable (селектор).

Точнее, я создал Drawable селектор в XML, а затем добавляют в них один вектор Drawable:

<?xml version="1.0" encoding="utf-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
    <item android:drawable="@drawable/vector_ic_action_add" /> 
</selector> 

Затем я использую этот «обернутую» рисуем в моем меню. Если вам нужна дополнительная информация о том, как это работает, посмотрите this очень полезный пост от Chris Banes.

+4

Я получаю исключения, даже когда обертываю чертежи, как это – ligi

+0

i love u man :) это работа !!!!!! У меня эта проблема около 7 дней и всегда ищут проблемы ♥♥♥ –

+0

Это решение не работает для библиотеки поддержки v 25.3.1 Используйте этот вместо https://stackoverflow.com/a/38507596/4579783 – bshears

20

Для поддержки версии перед леденцом, используйте

com.android.support:appcompat-v7:24.0.0 (или позже)

библиотека поддержки.

И тогда, вместо

ContextCompat.getDrawable(view.getContext(), id); 

использовать это один

AppCompatResources.getDrawable(view.getContext(), id); 
+0

Большое вам спасибо - это сработало для нас. Как вы узнали об этом? –

+0

Примечание: AppCompatDrawableManager - это частный API, поэтому это может быть нарушено в любой момент. См. Https://code.google.com/p/android/issues/detail?id=216903#c13 –

+0

У меня такая же проблема. Тогда я обнаружил, что библиотека поддержки была обновлена, и она не упоминается нигде где .... Через список ошибок разработчиков Android я понял ... –

Смежные вопросы