【问题标题】:Setting textColor from a Theme fails only on HTC Desire HD从主题设置 textColor 仅在 HTC Desire HD 上失败
【发布时间】:2011-04-07 11:27:51
【问题描述】:

问题:

我的应用程序在大多数设备上都能正常运行,但在 HTC Desire HD(Android 2.2.1)上崩溃。 (编辑: 2.3.3 仍然存在错误)

异常类 - android.content.res.Resources$NotFoundException

来源方法-Resources.loadColorStateList()

详情:

我正在使用主题设置 textColor。我在布局xml文件的TextView中声明了textColor ...

<TextView
    android:id="@+id/accountWarning"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@string/accountWarning"
    android:textSize="20sp"
    android:layout_marginTop="10dp"
    android:padding="10dp"
    android:textColor="?textColor"/>

并在资源主题文件中声明每个主题的 textColor 应该是什么...

<style name="Theme.TxtoolsDark" parent="Theme">
  <item name="textColor">#FFFFFF</item>
  <item name="autoCompleteTextViewTextColor">#000</item>    
</style>

<style name="Theme.TxtoolsLight" parent="Theme" >
  <item name="textColor">#000</item>
  <item name="autoCompleteTextViewTextColor">#000</item> 
</style>

如果我只是在我的 xml 文件中硬编码 textColor,它可以正常工作,所以它似乎无法理解 '?textColor' 应该让它查看我的主题.xml 文件。同样,这在我测试过的其他设备上运行良好,但在 HTC Desire HD 上失败。

错误:

堆栈跟踪的相关位是...

android.view.InflateException: Binary XML file line #10: Error inflating class <unknown>

Caused by: android.content.res.Resources$NotFoundException: File res/drawable-hdpi/scrollbar_handle_vertical.9.png from drawable resource ID #0x0: .xml extension required
at android.content.res.Resources.loadColorStateList(Resources.java:1842)
at android.content.res.TypedArray.getColorStateList(TypedArray.java:342)
at android.widget.TextView.<init>(TextView.java:665)

编辑: Eclipse 3.5.2 在我的 layout.xml 的图形布局选项卡中向我报告“无法解析属性“textColor”中的颜色值“?textColor””。但是,我仍然可以编译和构建,并且它仍然可以在 HTC Desire HD 以外的所有其他设备上运行。完整的代码在这个问题的底部。

编辑:2011 年 7 月 1 日

我注意到我有两个单独的堆栈跟踪(尽管我认为它靠近末尾的只有 1 行不同)...

java.lang.RuntimeException: Unable to resume activity  {uk.co.txttools.mobile.android.txttoolsmobile/uk.co.txttools.mobile.android.txttoolsmobile.pages.home.HomeTabs}: java.lang.RuntimeException: Unable to resume activity {uk.co.txttools.mobile.android.txttoolsmobile/uk.co.txttools.mobile.android.txttoolsmobile.pages.home.StandardHome}: android.view.InflateException: Binary XML file line #10: Error inflating class <unknown>
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3399)
at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3420)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2864)
at android.app.ActivityThread.access$2300(ActivityThread.java:136)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2179)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:143)
at android.app.ActivityThread.main(ActivityThread.java:5073)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.RuntimeException: Unable to resume activity {uk.co.txttools.mobile.android.txttoolsmobile/uk.co.txttools.mobile.android.txttoolsmobile.pages.home.StandardHome}: android.view.InflateException: Binary XML file line #10: Error inflating class <unknown>
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3399)
at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:170)
at android.app.LocalActivityManager.dispatchResume(LocalActivityManager.java:521)
at android.app.ActivityGroup.onResume(ActivityGroup.java:58)
at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1260)
at android.app.Activity.performResume(Activity.java:4011)
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3389)
... 12 more
Caused by: android.view.InflateException: Binary XML file line #10: Error inflating class <unknown>
at android.view.LayoutInflater.createView(LayoutInflater.java:513)
at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:563)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:618)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:621)
at android.view.LayoutInflater.inflate(LayoutInflater.java:407)
at android.view.LayoutInflater.inflate(LayoutInflater.java:320)
at android.view.LayoutInflater.inflate(LayoutInflater.java:276)
at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:217)
at android.app.Activity.setContentView(Activity.java:1701)
at uk.co.txttools.mobile.android.txttoolsmobile.pages.home.Home.createHomePage(Home.java:88)
at uk.co.txttools.mobile.android.txttoolsmobile.pages.home.StandardHome.createHomePage(StandardHome.java:74)
at uk.co.txttools.mobile.android.txttoolsmobile.pages.home.Home.onResume(Home.java:291)
at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1260)
at android.app.Activity.performResume(Activity.java:4011)
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3389)
... 18 more
Caused by: java.lang.reflect.InvocationTargetException
at android.widget.TextView.<init>(TextView.java:355)
at java.lang.reflect.Constructor.constructNative(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:446)
at android.view.LayoutInflater.createView(LayoutInflater.java:500)
... 33 more
Caused by: android.content.res.Resources$NotFoundException: File res/drawable-hdpi/scrollbar_handle_vertical.9.png from drawable resource ID #0x0: .xml extension required
at android.content.res.Resources.loadColorStateList(Resources.java:1842)
at android.content.res.TypedArray.getColorStateList(TypedArray.java:342)
at android.widget.TextView.<init>(TextView.java:665)
... 37 more

java.lang.RuntimeException: Unable to resume activity {uk.co.txttools.mobile.android.txttoolsmobile/uk.co.txttools.mobile.android.txttoolsmobile.pages.home.HomeTabs}: java.lang.RuntimeException: Unable to resume activity {uk.co.txttools.mobile.android.txttoolsmobile/uk.co.txttools.mobile.android.txttoolsmobile.pages.home.StandardHome}: android.view.InflateException: Binary XML file line #10: Error inflating class <unknown>
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2485)
at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2506)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1856)
at android.app.ActivityThread.access$1500(ActivityThread.java:132)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1038)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:143)
at android.app.ActivityThread.main(ActivityThread.java:4293)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.RuntimeException: Unable to resume activity {uk.co.txttools.mobile.android.txttoolsmobile/uk.co.txttools.mobile.android.txttoolsmobile.pages.home.StandardHome}: android.view.InflateException: Binary XML file line #10: Error inflating class <unknown>
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2485)
at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:170)
at android.app.LocalActivityManager.dispatchResume(LocalActivityManager.java:521)
at android.app.ActivityGroup.onResume(ActivityGroup.java:58)
at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1242)
at android.app.Activity.performResume(Activity.java:4004)
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2475)
... 12 more
Caused by: android.view.InflateException: Binary XML file line #10: Error inflating class <unknown>
at android.view.LayoutInflater.createView(LayoutInflater.java:518)
at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:568)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:623)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:626)
at android.view.LayoutInflater.inflate(LayoutInflater.java:408)
at android.view.LayoutInflater.inflate(LayoutInflater.java:320)
at android.view.LayoutInflater.inflate(LayoutInflater.java:276)
at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:231)
at android.app.Activity.setContentView(Activity.java:1742)
at uk.co.txttools.mobile.android.txttoolsmobile.pages.home.Home.createHomePage(Home.java:88)
at uk.co.txttools.mobile.android.txttoolsmobile.pages.home.StandardHome.createHomePage(StandardHome.java:74)
at uk.co.txttools.mobile.android.txttoolsmobile.pages.home.Home.onResume(Home.java:291)
at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1242)
at android.app.Activity.performResume(Activity.java:4004)
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2475)
... 18 more
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Constructor.constructNative(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:415)
at android.view.LayoutInflater.createView(LayoutInflater.java:505)
... 33 more
Caused by: android.content.res.Resources$NotFoundException: Resource is not a         ColorStateList (color or path): TypedValue{t=0x2/d=0x7f010001 a=-1}
at android.content.res.Resources.loadColorStateList(Resources.java:1822)
at android.content.res.TypedArray.getColorStateList(TypedArray.java:342)
at android.widget.TextView.<init>(TextView.java:693)
at android.widget.TextView.<init>(TextView.java:382)
... 36 more

编辑:7 月 4 日 - 完整代码

themes.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="Theme" parent="android:Theme">
    </style>

    <style name="Theme.TxtoolsDark" parent="Theme">
      <item name="textColor">#FFFFFF</item>
      <item name="autoCompleteTextViewTextColor">#000</item> 
    </style>

    <style name="Theme.TxtoolsLight" parent="Theme" >
      <item name="textColor">#000</item>
      <item name="autoCompleteTextViewTextColor">#000</item>
    </style>

</resources>

attrs.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <attr name="autoCompleteTextViewTextColor" format="reference|color" />
    <attr name="textColor" format="reference|color" />
</resources>

myLayoutFile.xml

<?xml version="1.0" encoding="utf-8"?>
<ScrollView android:id="@+id/ScrollView01" 
                android:layout_width="fill_parent" 
                android:layout_height="fill_parent" 
                xmlns:android="http://schemas.android.com/apk/res/android">
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    android:scrollbars="vertical" android:scrollbarAlwaysDrawVerticalTrack="true">
    <TextView
        android:id="@+id/accountWarning"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/accountWarning"
        android:textSize="20sp"
        android:layout_marginTop="10dp"
        android:padding="10dp"
        android:textColor="?textColor"/>
    <TextView
        android:id="@+id/haveAccountQuestion"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/haveAccountQuestion"
        android:textSize="20sp"
        android:layout_gravity="center_horizontal"
        android:padding="10dp"
        android:textColor="?textColor"/>
    <Button
        android:id="@+id/yes"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:padding="10dp"
        android:width="80dp"
        android:text="@string/yesHappy"
        android:textSize="15sp"
        android:layout_gravity="center_horizontal"/>
    <Button
        android:id="@+id/no"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:padding="10dp"
        android:width="80dp"
        android:text="@string/noSad"
        android:textSize="15sp"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="10dp"/>
    <ListView android:id="@android:id/list"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:cacheColorHint="#00000000"/>
</LinearLayout>
</ScrollView>

编辑:2011 年 7 月 5 日 我发现如果我使用 'android:textColorPrimary' 而不是 'textColor',HTC Desire HD 上不再出现错误,但文本颜色将始终保持不变系统 textColor 默认。在所有设备上,它都能按预期完美运行。

编辑:2011 年 7 月 6 日清晨基本上,HTC Desire HD 似乎忽略了任何用“?”设置的值。尽管我在上次编辑中描述了半修复,但我稍后在使用样式的页面上的应用程序中遇到错误。

编辑:2011 年 7 月 6 日下午晚些时候 通过在 Java 中粗略地设置文本颜色(取决于主题),我已经解决了一半的问题。但是,这还不适用于我的 ListView 中使用“样式”的文本。然而,我现在发现我的程序的所有其余部分都可以正常工作,尽管使用了'?textColor'!这意味着只有打开屏幕无法工作,这表明 HTC Desire HD 没有足够早地创建必要的主题或样式来破译“?textColor”! (或类似的东西!)这可能是关键信息!我可以在我的代码中交换任何内容以使其正常工作吗?

【问题讨论】:

    标签: android coding-style themes textcolor


    【解决方案1】:

    您在 cmets 中提到您在 Activity 上调用 setTheme,而不是在清单中的 Activity 上设置主题。请确保在该 Activity 的 onCreate 生命周期方法中调用 super.onCreate 和 setContent 之前调用 setTheme。这将防止在您的主题之前使用任何默认主题。

    我怀疑正在发生的事情是您在布局 XML 中使用“?textColor”,但此值仅在您的自定义主题和某些设备的默认主题中定义。其他设备在默认主题中没有定义的值。

    错误消息是一些被放入其中的值,最终解析为不能用作文本​​颜色的资源。文本颜色通常是一个 XML 状态列表,它指定用于某些状态的颜色,例如焦点,但如果您希望所有状态都使用相同的颜色,有时会使用直接颜色资源。

    就像我在另一条评论中提到的那样,我见过的大多数主题都没有直接的 textColor 值。相反,他们有一个 textViewStyle 指向一个样式,然后有一个 textColor。如果你想影响更多的东西,你可能想试试 colorForeground。通常 textViewStyle 会为 textColor 指定一个 XML 状态列表文件,然后它将使用 colorForeground 作为某些状态的颜色。

    【讨论】:

      【解决方案2】:

      这个片段不是必需的。主题应该在没有明确指定布局中任何地方的样式的情况下生效。

       android:textColor="?textColor"
      

      【讨论】:

      • 感谢您的回复吉姆!恐怕没有用。如果我删除该行,文本将恢复为默认颜色。如果我几个月前写这篇文章时没记错的话,它需要声明 "?textColor" 以确保它使用主题作为文本颜色。当然,它在我尝试过的所有设备上都可以正常工作(如果我保留这个片段)。我想知道我的设置是否与您想象的不同?还有其他想法吗?谢谢。
      • (在上面的评论中,我的意思是说原始代码在我尝试过的所有 other 设备上都可以正常工作)。
      • 凹凸。这仍然是一个问题。有没有人有更多的建议?谢谢。
      • 此问题仍未解决。有没有人也遇到过这个?
      • 你好,安迪。我认为我们遇到了同样的问题 - 我有一份报告说我们的一个应用程序在 HTC Desire HD 上崩溃了,我们也使用了可主题化的 textColor(尽管我们使用 style="@style/OurTheme").. 我猜你没有还没有找到解决办法?不幸的是,我无法访问失败的高清,所以我看不到堆栈跟踪。但我也必须修复问题......你碰巧有一个可以运行我的应用程序的高清,以便我可以看到堆栈跟踪并进行更多调试?我可以将在 (apphance.com) 的特殊 QA 模式下构建的应用程序发送给您,以便我可以远程调试它..
      【解决方案3】:

      我最终选择通过修改我的一些 xml 和 Java 文件来解决这个问题。这感觉并不理想,因为它会在代码中造成不一致,并使那些需要简化的主题变得过于复杂。但是,为了迎合 HTC Desire HD 用户,我已经屈服了。如果有人可以找到替代解决方案,请在此处发布。

      简单地说,我通过在 Java 静态方法中设置文本颜色来修复我的代码...

      public static void setTextColor(TextView tv) {
      
          if (CURRENT_THEME==TXTTOOLS_LIGHT){
              tv.setTextColor(Color.BLACK);
          }
          else if (CURRENT_THEME==TXTTOOLS_DARK){
              tv.setTextColor(Color.WHITE);
          }
      }
      

      或通过在 styles.xml 中创建各种样式(每种文本颜色一个),并在 Java 代码中调用相关的样式。

      SimpleCursorAdapter logins;
      if (Theme.getTheme()==Theme.TXTTOOLS_LIGHT){
          logins = new SimpleCursorAdapter(this, R.layout.username_row_light_theme, c, from, to);     
      }
      else if (Theme.getTheme()==Theme.TXTTOOLS_DARK){
          logins = new SimpleCursorAdapter(this, R.layout.username_row_dark_theme, c, from, to);  
      }
      

      【讨论】:

        【解决方案4】:

        “?”语法是在当前主题中引用一个样式,你在Manifest中设置你的主题吗?我在您提供的代码中没有看到它,所以我假设如果它已设置,它就在那里完成。 (这可能是其他 Jim 发表评论的原因 - 您的回复表明它没有被设置。)

        此外,您已经定义了两次“textColor”属性——一次在themes.xml 中,一次在attrs.xml 中。任何设备如何知道您指的是哪一个?因为您使用的是“?”语法,系统应该知道寻找样式属性,但我认为它不会显式检查资源类型。事实上,有效的语法包括资源类型,它可能有助于拥有“?style/textColor”。另外,尝试调用另一个“attrTextColor”来区分它和主题中的“textColor”属性。 (此外,“textColor”在我看来是一个错误的属性名称,因为它可能与属性“android:textColor”混淆 - 也许您应该将其命名为“txttoolsTextColor”或其他名称。因为系统应该知道查看您的包对于“textColor”资源,它真的不重要......除了你有一个错误,这可能是原因......)

        【讨论】:

        • 嗨,吉姆,为您的回复干杯!也许我没有说清楚的是应用程序的主题是由用户选择的。目前有两种选择;一个浅色的和深色的。因此,主题不在清单文件中设置,它由用户在应用程序的首选项屏幕上选择,并使用 Java 中的代码设置,例如:activity.setTheme(R.style.Theme_TxttoolsLight);关于您的主题.xml / attrs.xml 查询,每个主题的颜色都在主题.xml 中定义,而 attrs.xml 需要声明主题中的属性。 attrs.xml 本身没有定义颜色。
        【解决方案5】:

        我最近遇到了类似的问题。仅对于 Galaxy S 4G,我在放大视图时遇到以下错误:

        Caused by: android.content.res.Resources$NotFoundException: File res/drawable-hdpi/scrollbar_handle_vertical.9.png from drawable resource ID #0x0: .xml extension required
        

        这个错误代码非常无用,事实证明查看堆栈跟踪的顶部更有用,我发现:

        ComponentInfo{com.staircase3.opensignal/com.staircase3.opensignal.library.Tab_Overview}: android.view.InflateException: Binary XML file line #804: Error inflating class </code>
        

        然后查看第 804 行有问题的 XML 文件,我发现设置 android:cacheColorHint 存在问题。尽管我确实有一个自定义主题,但它并没有应用于我的 ListView 并且 cacheColorHint 只是硬编码的。修复很简单,如上所述在 java 中动态设置它:listview.setCacheColorHint。

        似乎在 java 中的某些视图变量而不是 XML 通常会导致较少的问题,平铺位图存在一个错误,也可以通过比在 java 中更动态地查看 tile 属性来解决(参见XML drawable Bitmap tileMode bug?

        看起来,对于某些型号的手机和布局,布局在所有 XML 都被解码之前就已经膨胀了。但这是推测,或者至少是解决这些问题的一种启发式方法。

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2012-01-27
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2011-06-07
          • 1970-01-01
          相关资源
          最近更新 更多