Android 通过反射获取DatePicker 中的控件,并改变其颜色

本文介绍了一种通过反射机制修改Android中DatePicker组件分割线颜色的方法。通过对NumberPicker内部类的字段进行操作,实现了对日期选择器中各部分颜色的定制化调整。

 

 

到最后也只是成功改变了中间部分的颜色。

 

 

 

   private void setDatePickerDividerColor(DatePicker datePicker) {
        // Divider changing:

        // 获取 mSpinners
        LinearLayout llFirst = (LinearLayout) datePicker.getChildAt(0);

        // 获取 NumberPicker
        LinearLayout mSpinners = (LinearLayout) llFirst.getChildAt(0);
        for (int i = 0; i < mSpinners.getChildCount(); i++) {
            NumberPicker picker = (NumberPicker) mSpinners.getChildAt(i);

            Field[] pickerFields = NumberPicker.class.getDeclaredFields();
            for (Field pf : pickerFields) {
                pf.setAccessible(true);
                String pfString = pf.getName();
                try {
                    if (pfString.equals("mSelectionDivider")) {
                        pf.set(picker, new ColorDrawable(Color.parseColor("#ffffff")));//设置分割线颜色
                        break;
                    } else if (pfString.equals("mInputText")) {
                        EditText mInputText = (EditText) pf.get(picker);//获得该属性对应的对象
                        mInputText.setTextColor(view.getResources().getColor(R.color.white));
                        break;
                    } else if (pfString.equals("mSelectorWheelPaint")) {
                        Paint mPaint = (Paint) pf.get(picker);//获得该属性对应的对象
                        mPaint.setColor(view.getResources().getColor(R.color.white));
                        break;
                    } else if (pfString.equals("mVirtualButtonPressedDrawable")) {
                        pf.set(picker, new ColorDrawable(Color.parseColor("#ffffff")));
                        break;
                    }
                } catch (IllegalArgumentException e) {
                    e.printStackTrace();
                } catch (Resources.NotFoundException e) {
                    e.printStackTrace();
                } catch (IllegalAccessException e) {
                    e.printStackTrace();
                }
            }
        }
    }

 

转载于:https://www.cnblogs.com/lipeineng/p/7903047.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值