2015-06-30 3 views
5

Я пробовал ответить here, но это не сработало для меня. Я использую xml в качестве фона и получаю исключение - Resources$NotFoundException: File res/drawable/list_selector_white.xml from drawable resource ID. Приложение запускается при запуске.

Странная деталь - это нормально работает на устройствах, работающих на Lollypop. В ОС < = KitKat, эта проблема воспроизводится.

XML, который раздувается в фрагменте:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:background="@drawable/list_selector_white" > 
    ....Other views here.... 

list_selector_white.xml

<!-- Selector style for listrow --> 
    <item android:drawable="@drawable/gradient_bg_white" android:state_pressed="false" android:state_selected="false"/> 
    <item android:drawable="@drawable/gradient_bg_hover" android:state_pressed="true"/> 
    <item android:drawable="@drawable/gradient_bg_hover" android:state_pressed="false" android:state_selected="true"/> 

gradient_bg_hover

<shape xmlns:android="http://schemas.android.com/apk/res/android" 
    android:shape="rectangle"> 
    <!-- Gradient BgColor for listrow Selected --> 
    <gradient 
     android:startColor="?attr/listViewRow" 
     android:centerColor="?attr/listViewRow" 
     android:endColor="?attr/listViewRow" 
     android:angle="270" /> 
</shape> 

Logcat:

E/AndroidRuntime(3879): android.view.InflateException: Binary XML file line #2: Error inflating class <unknown> 
E/AndroidRuntime(3879): at android.view.LayoutInflater.createView(LayoutInflater.java:620) 
E/AndroidRuntime(3879): at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56) 
E/AndroidRuntime(3879): at android.view.LayoutInflater.onCreateView(LayoutInflater.java:669) 
E/AndroidRuntime(3879): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:694) 
E/AndroidRuntime(3879): at android.view.LayoutInflater.inflate(LayoutInflater.java:469) 
E/AndroidRuntime(3879): at android.view.LayoutInflater.inflate(LayoutInflater.java:397) 
E/AndroidRuntime(3879): at android.view.LayoutInflater.inflate(LayoutInflater.java:353) 
E/AndroidRuntime(3879): at jsoup.LazyAdapterDoubleList.getView(LazyAdapterDoubleList.java:53) 
E/AndroidRuntime(3879): at android.widget.AbsListView.obtainView(AbsListView.java:2263) 
E/AndroidRuntime(3879): at android.widget.ListView.measureHeightOfChildren(ListView.java:1263) 
E/AndroidRuntime(3879): at android.widget.ListView.onMeasure(ListView.java:1175) 
E/AndroidRuntime(3879): at android.view.View.measure(View.java:16497) 
E/AndroidRuntime(3879): at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:719) 
E/AndroidRuntime(3879): at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:455) 
E/AndroidRuntime(3879): at android.view.View.measure(View.java:16497) 
E/AndroidRuntime(3879): at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:719) 
E/AndroidRuntime(3879): at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:455) 
E/AndroidRuntime(3879): at android.view.View.measure(View.java:16497) 
E/AndroidRuntime(3879): at android.support.v4.widget.SwipeRefreshLayout.onMeasure(SwipeRefreshLayout.java:577) 
E/AndroidRuntime(3879): at android.view.View.measure(View.java:16497) 
E/AndroidRuntime(3879): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5125) 
E/AndroidRuntime(3879): at android.widget.FrameLayout.onMeasure(FrameLayout.java:310) 
E/AndroidRuntime(3879): at android.view.View.measure(View.java:16497) 
E/AndroidRuntime(3879): at android.support.v4.widget.DrawerLayout.onMeasure(DrawerLayout.java:868) 
E/AndroidRuntime(3879): at android.view.View.measure(View.java:16497) 
E/AndroidRuntime(3879): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5125) 
E/AndroidRuntime(3879): at android.widget.FrameLayout.onMeasure(FrameLayout.java:310) 
E/AndroidRuntime(3879): at android.view.View.measure(View.java:16497) 
E/AndroidRuntime(3879): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5125) 
E/AndroidRuntime(3879): at com.android.internal.widget.ActionBarOverlayLayout.onMeasure(ActionBarOverlayLayout.java:327) 
E/AndroidRuntime(3879): at android.view.View.measure(View.java:16497) 
E/AndroidRuntime(3879): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5125) 
E/AndroidRuntime(3879): at android.widget.FrameLayout.onMeasure(FrameLayout.java:310) 
E/AndroidRuntime(3879): at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:2291) 
E/AndroidRuntime(3879): at android.view.View.measure(View.java:16497) 
E/AndroidRuntime(3879): at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:1916) 
E/AndroidRuntime(3879): at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1113) 
E/AndroidRuntime(3879): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1295) 
E/AndroidRuntime(3879): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1000) 
E/AndroidRuntime(3879): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5670) 
E/AndroidRuntime(3879): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:761) 
E/AndroidRuntime(3879): at android.view.Choreographer.doCallbacks(Choreographer.java:574) 
E/AndroidRuntime(3879): at android.view.Choreographer.doFrame(Choreographer.java:544) 
E/AndroidRuntime(3879): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747) 
E/AndroidRuntime(3879): at android.os.Handler.handleCallback(Handler.java:733) 
E/AndroidRuntime(3879): at android.os.Handler.dispatchMessage(Handler.java:95) 
E/AndroidRuntime(3879): at android.os.Looper.loop(Looper.java:136) 
E/AndroidRuntime(3879): at android.app.ActivityThread.main(ActivityThread.java:5017) 
E/AndroidRuntime(3879): at java.lang.reflect.Method.invoke(Native Method) 
E/AndroidRuntime(3879): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
E/AndroidRuntime(3879): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
E/AndroidRuntime(3879): Caused by: java.lang.reflect.InvocationTargetException 
E/AndroidRuntime(3879): at java.lang.reflect.Constructor.newInstance(Native Method) 
E/AndroidRuntime(3879): at android.view.LayoutInflater.createView(LayoutInflater.java:594) 
E/AndroidRuntime(3879): ... 50 more 
E/AndroidRuntime(3879): Caused by: android.content.res.Resources$NotFoundException: File res/drawable/list_selector_white.xml from drawable resource ID #0x7f02006a 
E/AndroidRuntime(3879): at android.content.res.Resources.loadDrawable(Resources.java:2096) 
E/AndroidRuntime(3879): at android.content.res.TypedArray.getDrawable(TypedArray.java:602) 
E/AndroidRuntime(3879): at android.view.View.<init>(View.jav 
W/ActivityManager( 589): Force finishing activity free.programming.programming/.MainActivity 
W/ActivityManager( 589): Activity pause timeout for ActivityRecord{655864a8 u0 free.programming.programming/.MainActivity t49 f} 

Любой свинец о том, как это исправить?

[Редактировать]
Я подозреваю, используя attr в Drawable вызывает вопросы. Первоначально я использовал простой @color/..., и все работало нормально.

+0

есть gradient_bg_hover цвет? – Blackbelt

+0

Nope. Его выталкиваемый xml –

+0

где доступно? 'Рез/вытяжка-v21'? : D – ataulm

ответ

5

Я, наконец, смог исправить проблему. Я отправлю ответ, чтобы он мог помочь будущим читателям.

Проблема в том, что мы не можем давать значения attr для item и gradient. Я исправил эту проблему, взяв разные xml-файлы для цветов.

Я закончил с использованием различных версий list_selector_white_1 и _2.xml к:

<!-- Selector style for listrow --> 
<item android:drawable="@drawable/gradient_bg_white_1" android:state_pressed="false" android:state_selected="false"/> 
<item android:drawable="@drawable/gradient_bg_hover_1" android:state_pressed="true"/> 
<item android:drawable="@drawable/gradient_bg_hover_1" android:state_pressed="false" android:state_selected="true"/> 

Аналогичным образом, я изменил gradient_bg_hover и gradient_bg_white к различным версиям.

Наконец, я создал атрибут list_selector с форматом integer и использовать его в фрагмент XML:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:background="?attr/list_selector" > 
    ....Other views here.... 

Я жду того времени, когда я могу поддерживать уровень> = 21 API в мое приложение, для того, чтобы удалите все эти хаки.

+0

Спасибо, ты спас меня - я определял угол радиуса с помощью attr/actionBarSize, и он рушился на pre-Lollipop. Я изменил его на 56dp и отлично работает - в моем случае это не очень важно, как много dps, что но если вам это действительно нужно, это отстой – user2302510

3

В принципе нет, это bug that was fixed in Lollipop. Предположение (до тех пор, пока вы не сможете сделать minSdkVersion=21) - создать другой файл XML с возможностью рисования для каждого цвета, который вам нужен (и предположим, что это атрибут темы).

Дубликат вопрос, ответы и комментарии обсудить эту ошибку: How to reference colour attribute in drawable?

8

У меня была такая же проблема. Проблема в том, что вы используете ?attr/ в своих возможностях. Замените его на @color или @drawable, и он должен уйти. Это, к сожалению, означает, что вам нужно собрать все, что подходит для каждой из ваших тем, оно намного более чище в леденец.

Отметьте this commit моего проекта, над которым я работаю, именно для решения этой проблемы.

Вы можете создать папку drawable-v21 и поместить под нее под тяжестью в надежде на хорошее время, когда вы можете поддерживать v21 +, но я решил пойти другим путем и расслоить различные цветовые ресурсы (что-то, что вы можете увидеть в главной ветке , У меня есть чирок и зеленые цвета по умолчанию).

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