Android 使用appcompat v7的自定义EditText样式
我创建了一个扩展EditText的自定义视图,并指定了一个属性样式来更改背景色调Android 使用appcompat v7的自定义EditText样式,android,android-custom-view,android-appcompat,Android,Android Custom View,Android Appcompat,我创建了一个扩展EditText的自定义视图,并指定了一个属性样式来更改背景色调 public class CustomEditText extends EditText { public CustomEditText (Context context) { this(context, null); } public CustomEditText (Context context, AttributeSet attrs) { this(
public class CustomEditText extends EditText {
public CustomEditText (Context context) {
this(context, null);
}
public CustomEditText (Context context, AttributeSet attrs) {
this(context, attrs, R.attr.customEditTextStyle);
}
public CustomEditText (Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, R.attr.customEditTextStyle);
}
// Some other code...
}
然后我添加了一个属性样式:
<resources>
<attr name="customEditTextStyle" format="reference" />
<resources>
有没有办法在自定义视图中应用AppCompat样式?这是AppCompat问题还是我在CustomEditText中做错了什么?任何想法都将不胜感激。谢谢 通过扩展android.support.v7.internal.widget.TintEditText解决了这个问题
AppCompat不支持自定义视图的小部件着色。从api 21开始,您必须为AppCompatEdit文本创建子类。所有受支持的小部件也是如此。使用AppCompat*获得着色和其他背面支持的功能
<style name="AppTheme.Base" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="colorPrimary">@color/blue</item>
<item name="colorPrimaryDark">@color/blue_dark</item>
<item name="colorAccent">@color/blue_accent</item>
<item name="customEditTextStyle">@style/CustomEditText</item>
</style>
<style name="CustomEditText" parent="Widget.AppCompat.EditText">
<item name="colorPrimary">@color/blue</item>
<item name="colorPrimaryDark">@color/blue_dark</item>
<item name="colorAccent">@color/blue_accent</item>
</style>
editText.getBackground().setColorFilter(getResources().getColor(R.color.your_color), PorterDuff.Mode.SRC_ATOP);