我实现了一个自定义的日期选择器,其中我需要为其内部的数字选择器(日期选择器内部使用数字选择器)设置自定义颜色,如下所示:
在this answer的帮助下,我可以使它看起来像这样:
但是,您看到的是实际日期显示为黄色而不是白色。
而且,我尝试在运行时这样做,如下所示:
npMonth.setOnValueChangedListener(new OnValueChangeListener() {
@Override
public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
EditText et = ((EditText) npMonth.getChildAt(0));
et.setTextColor(getResources().getColor(R.color.gold));
}
});
但是仍然没有运气。
如何只将中心文本的颜色更改为白色,而使顶部和底部的文本保持黄色?
最佳答案
最简单的方法
setNumberPickerTextColor(mNumberPicker);
public void setNumberPickerTextColor(NumberPicker numberPicker){
int color=Color.parseColor("#333333");
final int count = numberPicker.getChildCount();
for(int i = 0; i < count; i++){
View child = numberPicker.getChildAt(i);
if(child instanceof EditText){
try{
Field selectorWheelPaintField = numberPicker.getClass().getDeclaredField("mSelectorWheelPaint");
selectorWheelPaintField.setAccessible(true);
((Paint)selectorWheelPaintField.get(numberPicker)).setColor(color);
((EditText)child).setTextColor(color);
numberPicker.invalidate();
}
catch(NoSuchFieldException e){
Log.e("setNumberPickerColor1", ""+e);
}
catch(IllegalAccessException e){
Log.e("setNumberPickerColor2", ""+e);
}
catch(IllegalArgumentException e){
Log.e("setNumberPickerColor3", ""+e);
}
}
}
}