DatePicker自定义样式,选择年只显示后两位

1.实现效果预期

2.实现

2.1设置基本样式android:datePickerMode="spinner"。

<DatePicker
            android:id="@+id/dp_date"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            android:calendarViewShown="false"
            android:datePickerMode="spinner"
            />

2.2 代码调整自定义样式

首先隐藏分割线(将分割线设置为透明);然后设置背景图片改为自己想要的样式。调整年月日之间的间距便于将文字年月日放进去,年月日文字写入一个布局,浮在DatePicker上方,调整间距即可实现如图样式。

//自定义样式
 private void setDatePickerDividerColor(DatePicker datePicker) {
        // 获取 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);
           //调整年月日之间的间距
              LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(80,         LinearLayout.LayoutParams.WRAP_CONTENT);
        params.setMargins(30, 0, 30, 0);
        picker.setLayoutParams(params);


            //设置分割线颜色为透明
            Field[] pickerFields = NumberPicker.class.getDeclaredFields();
            for (Field pf : pickerFields) {
                if (pf.getName().equals("mSelectionDivider")) {
                    pf.setAccessible(true);
                    try {
                        //设置分割线颜色为透明
                        pf.set(picker, new ColorDrawable(Color.TRANSPARENT));
                    } catch (IllegalArgumentException e) {
                        e.printStackTrace();
                    } catch (Resources.NotFoundException e) {
                        e.printStackTrace();
                    } catch (IllegalAccessException e) {
                        e.printStackTrace();
                    }
                    break;
                }
            }

            //设置背景图片-实现想要的样式
          picker.setBackground(context.getDrawable(R.mipmap.XXXX)); 
            //设置选中的picker背景,未选中背景不同
            int finalI = i;
            picker.setOnScrollListener(new NumberPicker.OnScrollListener() {
                @Override
                public void onScrollStateChange(NumberPicker view, int scrollState) {
                   
                    if (scrollState == SCROLL_STATE_TOUCH_SCROLL) {
                                           picker.setBackground(context.getDrawable(R.mipmap.XXXX)); //选中背景图
                        for (int i = 0; i < mSpinners.getChildCount(); i++) {
                            NumberPicker picker = (NumberPicker) mSpinners.getChildAt(i);
                            if(i!=finalI){
                                //未选中背景图
                                picker.setBackground(context.getDrawable(R.XXXX1));
                            }

                        }
                    }
                }
            });
        }

        //设置年只显示后面两位--eg:22年而非2022年
        NumberPicker yearPicker = (NumberPicker) mSpinners.getChildAt(0);
        yearPicker.setFormatter(new NumberPicker.Formatter() {
            @Override
            public String format(int value) {
                String year= String.valueOf(value);
                return year.substring(2);
            }
        });

    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自定义 Java 的 DatePicker 控件只显示选择月,可以使用 JavaFX 中的 DatePicker 控件,并设置它的显示格式。 首先,需要在 JavaFX 应用程序中导入相应的包: ```java import java.time.LocalDate; import javafx.application.Application; import javafx.scene.Scene; import javafx.scene.control.DatePicker; import javafx.scene.layout.VBox; import javafx.stage.Stage; ``` 然后,在 JavaFX 的 start 方法中创建一个 DatePicker 控件,并设置其显示格式为只显示月,使用 setConverter 方法来实现: ```java @Override public void start(Stage primaryStage) { DatePicker datePicker = new DatePicker(); datePicker.setConverter(new StringConverter<LocalDate>() { private DateTimeFormatter dateFormatter = DateTimeFormatter.ofPattern("yyyyMM月"); @Override public String toString(LocalDate date) { if (date != null) { return dateFormatter.format(date); } else { return ""; } } @Override public LocalDate fromString(String string) { if (string != null && !string.isEmpty()) { return LocalDate.parse(string, dateFormatter); } else { return null; } } }); VBox vbox = new VBox(datePicker); Scene scene = new Scene(vbox, 200, 200); primaryStage.setScene(scene); primaryStage.show(); } ``` 在上面的代码中,我们创建了一个内部类 StringConverter,并重写了其 toString 和 fromString 方法来实现转换显示格式。在这个例子中,我们设置显示格式为 "yyyyMM月",即只显示月。这个格式可以根据需求进行调整。 最后,我们将 DatePicker 控件添加到一个 VBox 容器中,并在场景中显示出来。 通过以上的步骤,就可以实现自定义DatePicker 控件只显示选择月。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值