安卓中无需使用反射,修改DatePicker中的文字颜色、分割线高度、整个DatePicker的高度

前言

网上看了很多文章,都用到了反射,我尝试过了,在高版本安卓系统中,会出现无效的情况,因为在高版本系统上,官方对反射作出了限制。本篇文章根据DatePicker的布局结构去实现界面改造,DatePicker的界面布局结构如下图:
在这里插入图片描述

代码

因为代码很简单,所以不做过多的解释。

布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">
    <DatePicker
        android:id="@+id/datePicker"
        android:layout_width="match_parent"
        android:datePickerMode="spinner"
        android:calendarViewShown="false"
        android:background="#f1f2f3"
        android:layout_height="wrap_content"/>
</LinearLayout>
MainActivity.java
public class MainActivity extends AppCompatActivity {
    private DatePicker datePicker;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        datePicker=findViewById(R.id.datePicker);
        LinearLayout linearLayout1 = (LinearLayout) datePicker.getChildAt(0);//获取布局结构图中的第1个LinearLayout
        LinearLayout linearLayout2 = (LinearLayout) linearLayout1.getChildAt(0);//获取布局结构图中的第2个LinearLayout
        linearLayout2.setLayoutParams(new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,400));
        linearLayout2.getChildAt(2).setVisibility(View.GONE);//隐藏掉day的滚动控件
        NumberPicker numberPicker1 = (NumberPicker) linearLayout2.getChildAt(0);//“年”滚动控件
        NumberPicker numberPicker2 = (NumberPicker) linearLayout2.getChildAt(1);//“月”滚动控件
        //设置“年”滚动控件的宽和高
        numberPicker1.setLayoutParams(new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT));
        //设置“月”滚动控件的宽和高
        numberPicker2.setLayoutParams(new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT));
        numberPicker1.setSelectionDividerHeight(3);//设置“年”滚动控件分割线的高度为3像素
        numberPicker2.setSelectionDividerHeight(3);//设置“月”滚动控件分割线的高度为3像素
        numberPicker1.setTextColor(Color.parseColor("#ff0000"));//设置“年”滚动控件里面的字体颜色为红色
    }

}

截图

在这里插入图片描述

总结

本次的效果图中并未涉及到修改分割线的颜色,因为看了NumberPicker的方法结构图,如下所示:
在这里插入图片描述
并没有public方法去对分割线的颜色进行修改。本篇文章不推荐使用反射,如果想要修改分割线的颜色,请参看我的另一篇文章“修改DatePicker的分割线颜色”。
注意:我看过有些书籍,上面的第二个LinearLayout其实有些机型可能存在5个Child,也就是除了年、月、日滚动控件之外,还有2条分割线,如下图:
在这里插入图片描述所以需要对孩子的个数作出判断(ViewGroup有个getChildCount方法可以判断子视图的个数),然后做兼容性处理。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值