今天APP程序运行时突然异退,出现如下错误:
E/AndroidRuntime(18412): Caused by: java.lang.UnsupportedOperationException: Can't convert to color: type=0x1
E/AndroidRuntime(18412): at android.content.res.TypedArray.getColor(TypedArray.java:404)
E/AndroidRuntime(18412): at com.patrolcontrol.Helper.GroupLayout.init(GroupLayout.java:43)
E/AndroidRuntime(18412): at com.patrolcontrol.Helper.GroupLayout.<init>(GroupLayout.java:33)
经过反复尝试,这是由于程序中引入了一个自定义控件中引起的,GroupLayout是一个自定义控件,它引用了一个style,
style="@style/CommonGroupLayout",style又定义了一个自定义属性dividerColor属性<item name="dividerColor">@color/c8</item><color name="c8">#e1e1e1</color> 这样就出现了上述错误,将上述代码改成下面单句代码,问题消失。<item name="dividerColor">#e1e1e1</item>
<com.patrolcontrol.Helper.GroupLayout style="@style/CommonGroupLayout" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="@dimen/device_set_layout_padding" > .....</com.patrolcontrol.Helper.GroupLayout><style name="CommonGroupLayout"> <item name="dividerHeight">0.5dp</item> <!--<item name="dividerColor">@color/c8</item>--> (1) <item name="dividerColor">#e1e1e1</item> (2) <item name="itemSelector">@drawable/grouplayout_item_bg_selector</item> <item name="dividerPadding">@dimen/device_set_padding</item> <item name="android:background">@android:color/white</item></style> 自定义控件TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.GroupLayout);
mDividerColor = a.getColor(R.styleable.GroupLayout_dividerColor, 0x10); (3)
当程序执行到出现错误,原因在于(1)这局代码,将(1)代码改成(2),错误消失。