MaskedTimeField
MaskedTimeField 是一个文本输入组件,它允许用户输入 数字 作为时间,并在字段失去焦点时根据定义的掩码自动格式化输入。掩码指定了预期的时间格式,指导输入和显示。该组件支持灵活的解析、验证、本地化和值恢复,以实现一致的时间处理。
基础
MaskedTimeField 专为 仅时间 输入而构建。如果您正在寻找一个能够处理 日期 并具有类似掩码格式的组件,请查看 MaskedDateField。
您可以在没有参数或带参数的情况下实例化 MaskedTimeField。可以定义初始值、标签、占位符和用于值更改的事件监听器。
显示代码
- Java
掩码规则
MaskedTimeField 使用格式指示符定义时间的解析和显示方式。每个格式指示符以 % 开头,后跟表示时间组件的字母。
时间格式指示符
| 格式 | 描述 |
|---|---|
%H | 小时 (24小时制) |
%h | 小时 (12小时制) |
%m | 分钟 |
%s | 秒 |
%p | AM/PM |
修饰符
修饰符精细化时间组件的显示:
| 修饰符 | 描述 |
|---|---|
z | 零填充 |
s | 简短文本表示 |
l | 长文本表示 |
p | 紧凑数字 |
d | 十进制 (默认格式) |
这些选项允许灵活且符合当地习惯的时间格式。
时间格式本地化
MaskedTimeField 通过设置适当的区域设置支持本地化。这确保了时间输入和输出匹配地区的惯例。
field.setLocale(Locale.GERMANY);
这会影响 AM/PM 指示符的显示、分隔符的处理和数值的解析方式。
解析逻辑
MaskedTimeField 根据定义的时间掩码解析用户输入。它接受完整和简写的数字输入,可以有或没有分隔符,从而允许灵活输入,同时确保时间有效。解析行为取决于掩码定义的格式顺序(例如,%Hz:%mz 代表小时/分钟)。该格式决定了数字序列的解释方式。
示例解析场景
| 输入 | 掩码 | 解释为 |
|---|---|---|
900 | %Hz:%mz | 09:00 |
1345 | %Hz:%mz | 13:45 |
0230 | %hz:%mz %p | 02:30 AM |
1830 | %hz:%mz %p | 06:30 PM |
设置最小/最大限制
您可以使用 setMin() 和 setMax() 方法限制 MaskedTimeField 中允许的时间范围:
field.setMin(LocalTime.of(8, 0));
field.setMax(LocalTime.of(18, 0));
这两个方法接受类型为 java.time.LocalTime 的值。超出定义范围的输入被视为无效。
恢复值
MaskedTimeField 包括一个恢复功能,能够将字段的值重置为预定义的或原始的状态。这对于撤销更改或返回到默认时间非常有用。
field.setRestoreValue(LocalTime.of(12, 0));
field.restoreValue();
恢复值的方法
- 通过编程,调用
restoreValue() - 通过键盘,按下 ESC(这是默认的恢复键,除非被事件监听器重写)
显示代码
- Java
验证模式
您可以使用正则表达式通过 setPattern() 方法应用客户端验证规则:
field.setPattern("^\\d{2}:\\d{2}$");
此模式确保只有匹配 HH:mm 格式(两个数字,冒号,两个数字)的值被认为是有效的。
模式必须遵循 JavaScript RegExp 语法,如 此处 所述。
该字段尝试根据当前掩码解析和格式化数字时间输入。然而,用户仍然可以手动输入与预期格式不匹配的值。如果输入在语法上有效但在语义上不正确或无法解析(例如 99:99),则它可能通过模式检查,但在逻辑验证中失败。即使设置了正则表达式模式,您仍然应该在应用逻辑中验证输入值,以确保时间既格式正确又有意义。
时间选择器
MaskedTimeField 包括一个内置的时间选择器,允许用户通过视觉方式选择时间,而不是键入。这提高了对于技术水平较低的用户的可用性,或者在需要精确输入的情况下。
显示代码
- Java
访问选择器
您可以使用 getPicker() 访问时间选择器:
TimePicker picker = field.getPicker();
显示/隐藏选择器图标
使用 setIconVisible() 显示或隐藏字段旁的时钟图标:
picker.setIconVisible(true); // 显示图标
自动打开行为
您可以配置选择器在用户与字段交互时自动打开(例如点击、按 Enter 键或方向键):
picker.setAutoOpen(true);
为了确保用户只能通过选择器选择时间(而不能手动输入),请结合以下两个设置:
field.getPicker().setAutoOpen(true); // 在用户交互时打开选择器
field.setAllowCustomValue(false); // 禁用手动文本输入
此设置确保所有时间输入都通过选择器 UI,这在您想要严格控制格式并消除键入输入的解析问题时非常有用。
手动打开选择器
要通过编程打开时间选择器:
picker.open();
或使用别名:
picker.show(); // 与 open() 相同
设置选择器步长
您可以使用 setStep() 定义选择器中可选时间之间的间隔。这使您能够控制时间选项的粒度——非常适合在 15 分钟的时间块中调度等场景。
field.getPicker().setStep(Duration.ofMinutes(15));
步长必须能整除一个小时或全天。否则,将抛出异常。
这确保下拉列表中包含可预测、均匀间隔的值,例如 09:00、09:15、09:30 等。
MaskedTimeFieldSpinner
MaskedTimeFieldSpinner 通过添加旋转控件扩展了 MaskedTimeField,使用户能够使用箭 头键或 UI 按钮递增或递减时间。它提供了更引导式的交互方式,尤其适合于桌面应用程序。
显示代码
- Java
关键功能
-
交互式时间步进:
使用箭头键或旋转按钮递增或递减时间值。 -
可自定义的旋转单位:
通过setSpinField()选择要修改的时间部分:spinner.setSpinField(MaskedTimeFieldSpinner.SpinField.MINUTE);选项包括
HOUR、MINUTE、SECOND和MILLISECOND。 -
最小/最大边界:
继承了使用setMin()和setMax()设置的最小和最大允许时间的支持。 -
格式化输出:
与来自MaskedTimeField的掩码和本地化设置完全兼容。
示例:按小时配置步进
MaskedTimeFieldSpinner spinner = new MaskedTimeFieldSpinner();
spinner.setSpinField(MaskedTimeFieldSpinner.SpinField.HOUR);