it-roy-ru.com

Не удается преобразовать в цвет: ошибка type = 0x2 при надувании макета во фрагменте, но только в Samsung Galaxy и Note 4

Я работаю над простым приложением с заданием и использую фрагменты. Один экран с некоторыми элементами. Когда я компилирую и запускаю приложение, оно работает нормально, за исключением Samsung Galaxy s3 и note 4. Я не получаю его из stacktrace, что не так.

01-16 16:25:05.915: E/AndroidRuntime(23174): Java.lang.RuntimeException: Unable to start activity ComponentInfo{com.test/com.test.MainActivity}: Android.view.InflateException: Binary XML file line #37: Error inflating class com.Android.internal.widget.ActionBarView
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:2292)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.app.ActivityThread.handleLaunchActivity(ActivityThread.Java:2350)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.app.ActivityThread.access$800(ActivityThread.Java:163)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:1257)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.os.Handler.dispatchMessage(Handler.Java:102)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.os.Looper.loop(Looper.Java:157)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.app.ActivityThread.main(ActivityThread.Java:5335)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Java.lang.reflect.Method.invokeNative(Native Method)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Java.lang.reflect.Method.invoke(Method.Java:515)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.Java:1265)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:1081)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at dalvik.system.NativeStart.main(Native Method)
01-16 16:25:05.915: E/AndroidRuntime(23174): Caused by: Android.view.InflateException: Binary XML file line #37: Error inflating class com.Android.internal.widget.ActionBarView
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.createView(LayoutInflater.Java:626)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.createViewFromTag(LayoutInflater.Java:702)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.rInflate(LayoutInflater.Java:761)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.rInflate(LayoutInflater.Java:769)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.inflate(LayoutInflater.Java:498)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.inflate(LayoutInflater.Java:398)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.inflate(LayoutInflater.Java:354)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.Android.internal.policy.impl.PhoneWindow.generateLayout(PhoneWindow.Java:3253)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.Android.internal.policy.impl.PhoneWindow.installDecor(PhoneWindow.Java:3327)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.Android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.Java:336)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.app.Activity.setContentView(Activity.Java:1973)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.test.MainActivity.onCreate(MainActivity.Java:28)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.app.Activity.performCreate(Activity.Java:5389)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.app.Instrumentation.callActivityOnCreate(Instrumentation.Java:1105)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:2256)
01-16 16:25:05.915: E/AndroidRuntime(23174):    ... 11 more
01-16 16:25:05.915: E/AndroidRuntime(23174): Caused by: Java.lang.reflect.InvocationTargetException
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Java.lang.reflect.Constructor.constructNative(Native Method)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Java.lang.reflect.Constructor.newInstance(Constructor.Java:423)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.createView(LayoutInflater.Java:600)
01-16 16:25:05.915: E/AndroidRuntime(23174):    ... 25 more
01-16 16:25:05.915: E/AndroidRuntime(23174): Caused by: Android.view.InflateException: Binary XML file line #35: Error inflating class Android.widget.TextView
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.createView(LayoutInflater.Java:626)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.Android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.Java:56)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.onCreateView(LayoutInflater.Java:675)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.createViewFromTag(LayoutInflater.Java:700)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.rInflate(LayoutInflater.Java:761)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.rInflate(LayoutInflater.Java:769)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.inflate(LayoutInflater.Java:498)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.inflate(LayoutInflater.Java:398)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.Android.internal.widget.ActionBarView.initTitle(ActionBarView.Java:1131)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.Android.internal.widget.ActionBarView.setDisplayOptions(ActionBarView.Java:947)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at com.Android.internal.widget.ActionBarView.<init>(ActionBarView.Java:392)
01-16 16:25:05.915: E/AndroidRuntime(23174):    ... 28 more
01-16 16:25:05.915: E/AndroidRuntime(23174): Caused by: Java.lang.reflect.InvocationTargetException
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Java.lang.reflect.Constructor.constructNative(Native Method)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Java.lang.reflect.Constructor.newInstance(Constructor.Java:423)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.view.LayoutInflater.createView(LayoutInflater.Java:600)
01-16 16:25:05.915: E/AndroidRuntime(23174):    ... 38 more
01-16 16:25:05.915: E/AndroidRuntime(23174): Caused by: Java.lang.UnsupportedOperationException: Can't convert to color: type=0x2
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.content.res.TypedArray.getColor(TypedArray.Java:327)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.widget.TextView.<init>(TextView.Java:945)
01-16 16:25:05.915: E/AndroidRuntime(23174):    at Android.widget.TextView.<init>(TextView.Java:863)
01-16 16:25:05.915: E/AndroidRuntime(23174):    ... 41 more

И макет из фрагмента:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:tools="http://schemas.Android.com/tools"
    Android:id="@+id/layout"
    Android:layout_width="fill_parent"
    Android:layout_height="fill_parent"
    Android:orientation="vertical"
    tools:context="com.locker.theme.one.MainActivity$PlaceholderFragment" >

    <RelativeLayout
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:layout_weight=".14"
        Android:clickable="true"
        Android:gravity="center" >

        <DigitalClock
            Android:id="@+id/digitalClock"
            Android:layout_width="match_parent"
            Android:layout_height="wrap_content"
            Android:gravity="center"
            Android:textAppearance="?android:attr/textAppearanceLarge"
            Android:textColor="@Android:color/white"
            Android:textSize="66sp" />
    </RelativeLayout>

    <RelativeLayout
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:layout_weight=".14"
        Android:gravity="center" >

        <ProgressBar
            Android:id="@+id/progress"
            style="?android:attr/progressBarStyleInverse"
            Android:layout_width="wrap_content"
            Android:layout_height="wrap_content"
            Android:layout_centerInParent="true"
            Android:layout_gravity="center"
            Android:layout_marginBottom="8dp"
            Android:visibility="gone" />

        <Button
            Android:id="@+id/activateBtn"
            Android:layout_width="fill_parent"
            Android:layout_height="wrap_content"
            Android:background="@color/material_deep_teal_200"
            Android:gravity="center"
            Android:layout_marginLeft="@dimen/activity_horizontal_margin"
            Android:layout_marginRight="@dimen/activity_horizontal_margin"
            Android:text="Test" />
    </RelativeLayout>

</LinearLayout>

Это стиль, который я использую:

<resources>

    <!--
        Base application theme, dependent on API level. This theme is replaced
        by AppBaseTheme from res/values-vXX/styles.xml on newer devices.


    -->
    <style name="AppBaseTheme" parent="Android:Theme.Light">
        <!--
            Theme customizations available in newer API levels can go in
            res/values-vXX/styles.xml, while customizations related to
            backward-compatibility can go here.


        -->
    </style>

    <!-- Application theme. -->

    <style name="AppTheme" parent="Android:Theme.Material">
        <!-- Main theme colors -->
    </style>

</resources>

Я немного погуглил, но не нашел идеи, которая могла бы рассказать мне, что происходит. Любые очки были бы отличными. Спасибо

29
user1140656

Я столкнулся с той же проблемой, которая была вызвана использованием attributes в качестве ссылки на color в xml drawable. Как уже упоминалось здесь на API <21, вы не можете использовать attrs для color в xml drawable. Таким образом, единственный способ - использовать ссылку на ресурс цвета (@color/YOURS_COLOR) или использовать формат #RGB.

Поэтому, если вы хотите использовать xml drawable с цветами, зависящими от темы, вы должны создать рисование для каждой темы;

62
mohax

У меня была такая же проблема на устройствах API 10, и она была вызвана использованием темы для API 11+ (из appcompat) . Для быстрого решения вы можете найти следующее объявление темы в styles.xml

<style name="AppBaseTheme" parent="...">
...
<style name="AppTheme" parent="...">

И Правка на:

<style name="AppBaseTheme" parent="Android:Theme.Light">
...
<style name="AppTheme" parent="Android:Theme.Light">
1
qmaq

Я столкнулся с этим при использовании сторонних lib https://github.com/hoang8f/Android-flat-button после того, как я обновил gradle до 3.0.1. 

Не идеально, но унизительная версия Gradle, похоже, исправила ошибку 

Это изменение требует обновления 2 файлов: 

  1. Проект build.gradle с

    com.Android.tools.build:gradle:2.3.3

  2. gradle/wrapper/gradle-wrapper.properties с

    distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.Zip

0
Gene Bo

Измените «AppTheme», чтобы не использовать материал. Например попробуйте:

<style name="AppTheme" parent="Android:Theme.Holo">

</style>

У меня была очень похожая проблема на моем Samsung Galaxy Tab Pro 8.4 под управлением Android 4.2. Это сработало, когда я изменил Styles.xml, чтобы использовать «Android: Theme.Holo» или «Theme.AppCompat.Light.DarkActionBar».

Я не смог найти никакой информации о том, почему именно это происходит и почему это влияет только на продукты Samsung. Если вы действительно хотите включить материал в качестве стиля, попробуйте добавить другой файл стиля для устройств с уровнем API 21 или выше. Подробнее об этом здесь в разделе «Выберите тему на основе версии платформы»

Пожалуйста, держите нас в курсе, если вы найдете какие-либо другие исправления.

0
Brendan L