harmony 鸿蒙Time Picker Dialog Box (TimePickerDialog)
Time Picker Dialog Box (TimePickerDialog)
A time picker dialog box is a dialog box that allows users to select a time from the 24-hour range through scrolling.
NOTE
The APIs of this module are supported since API version 8. Updates will be marked with a superscript to indicate their earliest API version.
The functionality of this module depends on UI context. This means that the APIs of this module cannot be used where the UI context is unclear. For details, see UIContext.
Since API version 10, you can use the showTimePickerDialog API in UIContext, which ensures that the time picker dialog box is shown in the intended UI instance.
TimePickerDialog
show
static show(options?: TimePickerDialogOptions)
Shows a time picker dialog box.
Atomic service API: This API can be used in atomic services since API version 11.
System capability: SystemCapability.ArkUI.ArkUI.Full
Parameters
Name | Type | Mandatory | Description |
---|---|---|---|
options | TimePickerDialogOptions | No | Parameters of the time picker dialog box. |
TimePickerDialogOptions
Inherited from TimePickerOptions.
System capability: SystemCapability.ArkUI.ArkUI.Full
Name | Type | Mandatory | Description |
---|---|---|---|
useMilitaryTime | boolean | No | Whether to display time in 24-hour format. The 12-hour format is used by default. Default value: false NOTE When in the 12-hour format, the AM/PM zone does not change depending on the hour portion. Atomic service API: This API can be used in atomic services since API version 11. |
disappearTextStyle10+ | PickerTextStyle | No | Font color, font size, and font weight for the top and bottom items. Default value: { color: ‘#ff182431’, font: { size: ‘14fp’, weight: FontWeight.Regular } } Atomic service API: This API can be used in atomic services since API version 11. |
textStyle10+ | PickerTextStyle | No | Font color, font size, and font weight of all items except the top, bottom, and selected items. Default value: { color: ‘#ff182431’, font: { size: ‘16fp’, weight: FontWeight.Regular } } Atomic service API: This API can be used in atomic services since API version 11. |
selectedTextStyle10+ | PickerTextStyle | No | Font color, font size, and font weight of the selected item. Default value: { color: ‘#ff007dff’, font: { size: ‘20vp’, weight: FontWeight.Medium } } Atomic service API: This API can be used in atomic services since API version 11. |
acceptButtonStyle12+ | PickerDialogButtonStyle | No | Style of the accept button. NOTE In the acceptButtonStyle and cancelButtonStyle configurations, only one primary field can be set to true at most. If both the primary fields are set to true, neither will take effect. Atomic service API: This API can be used in atomic services since API version 12. |
cancelButtonStyle12+ | PickerDialogButtonStyle | No | Style of the cancel button. NOTE In the acceptButtonStyle and cancelButtonStyle configurations, only one primary field can be set to true at most. If both the primary fields are set to true, neither will take effect. Atomic service API: This API can be used in atomic services since API version 12. |
alignment10+ | DialogAlignment | No | Alignment mode of the dialog box in the vertical direction. Default value: DialogAlignment.Default Atomic service API: This API can be used in atomic services since API version 11. |
offset10+ | Offset | No | Offset of the dialog box based on the alignment settings. Default value: { dx: 0 , dy: 0 } Atomic service API: This API can be used in atomic services since API version 11. |
maskRect10+ | Rectangle | No | Mask area of the dialog box. Events outside the mask area are transparently transmitted, and events within the mask area are not. Default value: { x: 0, y: 0, width: ‘100%’, height: ‘100%’ } Atomic service API: This API can be used in atomic services since API version 11. |
onAccept | (value: TimePickerResult) => void | No | Callback invoked when the OK button in the dialog box is clicked. Atomic service API: This API can be used in atomic services since API version 11. |
onCancel | () => void | No | Callback invoked when the Cancel button in the dialog box is clicked. Atomic service API: This API can be used in atomic services since API version 11. |
onChange | (value: TimePickerResult) => void | No | Callback invoked when the text picker in the dialog box snaps to the selected item. Atomic service API: This API can be used in atomic services since API version 11. |
backgroundColor11+ | ResourceColor | No | Backplane color of the dialog box. Default value: Color.Transparent NOTE When backgroundColor is set to a non-transparent color, backgroundBlurStyle must be set to BlurStyle.NONE; otherwise, the color display may not meet the expected effect. Atomic service API: This API can be used in atomic services since API version 12. |
backgroundBlurStyle11+ | BlurStyle | No | Background blur style of the dialog box. Default value: BlurStyle.COMPONENT_ULTRA_THICK NOTE Setting this parameter to BlurStyle.NONE disables the background blur. When backgroundBlurStyle is set to a value other than NONE, do not set backgroundColor. If you do, the color display may not produce the expected visual effect. Atomic service API: This API can be used in atomic services since API version 12. |
backgroundBlurStyleOptions18+ | BackgroundBlurStyleOptions | No | Options for customizing the background blur style. Atomic service API: This API can be used in atomic services since API version 18. |
backgroundEffect18+ | BackgroundEffectOptions | No | Options for customizing the background effect. Atomic service API: This API can be used in atomic services since API version 18. |
onDidAppear12+ | () => void | No | Event callback when the dialog box appears. NOTE 1. The normal timing sequence is as follows: onWillAppear > onDidAppear > (onAccept/onCancel/onChange) > onWillDisappear > onDidDisappear. 2. You can set the callback event for changing the dialog box display effect in onDidAppear. The settings take effect next time the dialog box appears. 3. If the user closes the dialog box immediately after it appears, onWillDisappear is invoked before onDidAppear. 4. If the dialog box is closed before its entrance animation is finished, this callback is not invoked. Atomic service API: This API can be used in atomic services since API version 12. |
onDidDisappear12+ | () => void | No | Event callback when the dialog box disappears. NOTE 1. The normal timing sequence is as follows: onWillAppear > onDidAppear > (onAccept/onCancel/onChange) > onWillDisappear > onDidDisappear. Atomic service API: This API can be used in atomic services since API version 12. |
onWillAppear12+ | () => void | No | Event callback when the dialog box is about to appear. NOTE 1. The normal timing sequence is as follows: onWillAppear > onDidAppear > (onAccept/onCancel/onChange) > onWillDisappear > onDidDisappear. 2. You can set the callback event for changing the dialog box display effect in onWillAppear. The settings take effect next time the dialog box appears. Atomic service API: This API can be used in atomic services since API version 12. |
onWillDisappear12+ | () => void | No | Event callback when the dialog box is about to disappear. NOTE 1. The normal timing sequence is as follows: onWillAppear > onDidAppear > (onAccept/onCancel/onChange) > onWillDisappear > onDidDisappear. 2. If the user closes the dialog box immediately after it appears, onWillDisappear is invoked before onDidAppear. Atomic service API: This API can be used in atomic services since API version 12. |
shadow12+ | ShadowOptions |ShadowStyle | No | Shadow of the dialog box. Default value on 2-in-1 devices: ShadowStyle.OUTER_FLOATING_MD when the dialog box is focused and ShadowStyle.OUTER_FLOATING_SM otherwise Atomic service API: This API can be used in atomic services since API version 12. |
dateTimeOptions12+ | DateTimeOptions | No | Whether to display a leading zero for the hours and minutes. Currently only the configuration of the hour and minute parameters is supported. Default value: hour: In the 24-hour format, it defaults to 2-digit, which means a leading zero is used; In the 12-hour format, it defaults to numeric, which means no leading zero is used. minute: defaults to 2-digit, which means a leading zero is used. Atomic service API: This API can be used in atomic services since API version 12. |
enableHoverMode14+ | boolean | No | Whether to enable the hover mode. Default value: false, meaning not to enable the hover mode. Atomic service API: This API can be used in atomic services since API version 14. |
hoverModeArea14+ | HoverModeAreaType | No | Display area of the dialog box in hover mode. Default value: HoverModeAreaType.BOTTOM_SCREEN Atomic service API: This API can be used in atomic services since API version 14. |
onEnterSelectedArea16+ | Callback<TimePickerResult> | No | Represents the callback triggered during the scrolling of the text picker when an item enters the divider area. Compared to the onChange event, this event is triggered earlier, specifically when the scroll distance of the current column exceeds half the height of the selected item, which indicates that the item has entered the divider area. NOTE When enableCascade is set to true, using this callback is not recommended due to the interdependent relationship between the AM/PM and hour columns. This callback indicates the moment an option enters the divider area during scrolling, and only the value of the currently scrolled column will change. The values of other non-scrolled columns will remain unchanged. Atomic service API: This API can be used in atomic services since API version 16. |
enableCascade16+ | boolean | No | Whether the AM/PM indicator automatically switches based on the hour in 12-hour format. Default value: false. The value true means that the AM/PM indicator automatically switches based on the hour in 12-hour format, and false means the opposite. Atomic service API: This API can be used in atomic services since API version 16. |
enableHapticFeedback16+ | boolean | No | Whether to enable haptic feedback. The value true means to enable haptic feedback, and false means the opposite. The default value is true. Atomic service API: This API can be used in atomic services since API version 16. Note: To enable haptic feedback, you must declare the ohos.permission.VIBRATE permission under requestPermissions in the module.json5 file of the project. “requestPermissions”: [{“name”: “ohos.permission.VIBRATE”}] |
Handling in the case of exceptions
Exception | Result |
---|---|
The start time is later than the end time. | Both start time and end time are set to their default values. |
The selected time is earlier than the start time. | The selected time is set to the start time. |
The selected time is later than the end time. | The selected time is set to the end time. |
The start time is later than the current system time, and the selected time is not set. | The selected time is set to the start time. |
The end time is earlier than the current system time, and the selected time is not set. | The selected time is set to the end time. |
The time format is invalid, such as ‘01:61:61’. | The default value is used. |
Example
NOTE
For clarity in UI execution context, you are advised to use the showTimePickerDialog API in UIContext.
Example 1: Setting the Display Time
This example demonstrates how to set the display time using useMilitaryTime, dateTimeOptions, and format.
@Entry
@Component
struct TimePickerDialogExample {
private selectTime: Date = new Date('2020-12-25T08:30:00')
build() {
Column() {
Button("TimePickerDialog 12-hour format")
.margin(20)
.onClick(() => {
TimePickerDialog.show({
selected: this.selectTime,
format: TimePickerFormat.HOUR_MINUTE,
useMilitaryTime: false,
dateTimeOptions: { hour: "numeric", minute: "2-digit" },
onAccept: (value: TimePickerResult) => {
// Set selectTime to the time when the OK button is clicked. In this way, when the dialog box is displayed again, the selected time is the time when the operation was confirmed last time.
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute)
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
}
},
onCancel: () => {
console.info("TimePickerDialog:onCancel()")
},
onChange: (value: TimePickerResult) => {
console.info("TimePickerDialog:onChange()" + JSON.stringify(value))
},
onDidAppear: () => {
console.info("TimePickerDialog:onDidAppear()")
},
onDidDisappear: () => {
console.info("TimePickerDialog:onDidDisappear()")
},
onWillAppear: () => {
console.info("TimePickerDialog:onWillAppear()")
},
onWillDisappear: () => {
console.info("TimePickerDialog:onWillDisappear()")
}
})
})
Button("TimePickerDialog 24-hour format")
.margin(20)
.onClick(() => {
TimePickerDialog.show({
selected: this.selectTime,
format: TimePickerFormat.HOUR_MINUTE_SECOND,
useMilitaryTime: true,
onAccept: (value: TimePickerResult) => {
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute)
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
}
},
})
})
}.width('100%')
}
}
Example 2: Customizing the Style
In this example, disappearTextStyle, textStyle, selectedTextStyle, acceptButtonStyle, and cancelButtonStyle are configured to customize the text and button style.
// xxx.ets
@Entry
@Component
struct TimePickerDialogExample {
private selectTime: Date = new Date('2020-12-25T08:30:00')
build() {
Column() {
Button("TimePickerDialog 24-hour format")
.margin(20)
.onClick(() => {
TimePickerDialog.show({
disappearTextStyle: { color: '#297bec', font: { size: 15, weight: FontWeight.Lighter } },
textStyle: { color: Color.Black, font: { size: 20, weight: FontWeight.Normal } },
selectedTextStyle: { color: Color.Blue, font: { size: 30, weight: FontWeight.Bolder } },
acceptButtonStyle: {
type: ButtonType.Normal,
style: ButtonStyleMode.NORMAL,
role: ButtonRole.NORMAL,
fontColor: 'rgb(81, 81, 216)',
fontSize: '26fp',
fontWeight: FontWeight.Bolder,
fontStyle: FontStyle.Normal,
fontFamily: 'sans-serif',
backgroundColor: '#A6ACAF',
borderRadius: 20
},
cancelButtonStyle: {
type: ButtonType.Normal,
style: ButtonStyleMode.NORMAL,
role: ButtonRole.NORMAL,
fontColor: Color.Blue,
fontSize: '16fp',
fontWeight: FontWeight.Normal,
fontStyle: FontStyle.Italic,
fontFamily: 'sans-serif',
backgroundColor: '#50182431',
borderRadius: 10
},
onAccept: (value: TimePickerResult) => {
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute)
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
}
}
})
})
}.width('100%')
}
}
Example 3: Configuring a Dialog Box in the Hover State
This example demonstrates how to set the layout area of a dialog box in hover mode on a foldable device.
@Entry
@Component
struct TimePickerDialogExample {
private selectTime: Date = new Date('2020-12-25T08:30:00');
build() {
Column() {
Button("TimePickerDialog 12-hour format")
.margin(20)
.onClick(() => {
TimePickerDialog.show ({ // You are advised to use this.getUIContext().showTimePickerDialog().
selected: this.selectTime,
disappearTextStyle: { color: Color.Red, font: { size: 15, weight: FontWeight.Lighter } },
textStyle: { color: Color.Black, font: { size: 20, weight: FontWeight.Normal } },
selectedTextStyle: { color: Color.Blue, font: { size: 30, weight: FontWeight.Bolder } },
onAccept: (value: TimePickerResult) => {
// Set selectTime to the time when the OK button is clicked. In this way, when the dialog box is displayed again, the selected time is the time when the operation was confirmed last time.
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute);
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value));
}
},
onCancel: () => {
console.info("TimePickerDialog:onCancel()");
},
onChange: (value: TimePickerResult) => {
console.info("TimePickerDialog:onChange()" + JSON.stringify(value));
},
onDidAppear: () => {
console.info("TimePickerDialog:onDidAppear()");
},
onDidDisappear: () => {
console.info("TimePickerDialog:onDidDisappear()");
},
onWillAppear: () => {
console.info("TimePickerDialog:onWillAppear()");
},
onWillDisappear: () => {
console.info("TimePickerDialog:onWillDisappear()");
},
enableHoverMode: true,
hoverModeArea: HoverModeAreaType.TOP_SCREEN
})
})
}.width('100%')
}
}
Example 4: Setting the Dialog Box Position
This example demonstrates how to set the position of a dialog box using alignment and offset.
// xxx.ets
@Entry
@Component
struct TimePickerDialogExample {
private selectTime: Date = new Date('2020-12-25T08:30:00')
build() {
Column() {
Button("TimePickerDialog")
.margin(20)
.onClick(() => {
TimePickerDialog.show({
alignment: DialogAlignment.Center,
offset: { dx: 20 , dy: 0 },
onAccept: (value: TimePickerResult) => {
// Set selectTime to the time when the OK button is clicked. In this way, when the dialog box is displayed again, the selected time is the time when the operation was confirmed last time.
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute)
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
}
}
})
})
}.width('100%')
}
}
Example 5: Setting the Mask Area
This example demonstrates how to set the mask area using maskRect.
// xxx.ets
@Entry
@Component
struct TimePickerDialogExample {
private selectTime: Date = new Date('2020-12-25T08:30:00')
build() {
Column() {
Button("TimePickerDialog")
.margin(20)
.onClick(() => {
TimePickerDialog.show({
maskRect: { x: 30, y: 60, width: '100%', height: '60%' },
onAccept: (value: TimePickerResult) => {
// Set selectTime to the time when the OK button is clicked. In this way, when the dialog box is displayed again, the selected time is the time when the operation was confirmed last time.
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute)
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
}
}
})
})
}.width('100%')
}
}
Example 6: Setting the Background
This example demonstrates how to set the mask area using maskRect.
// xxx.ets
@Entry
@Component
struct TimePickerDialogExample {
private selectTime: Date = new Date('2020-12-25T08:30:00')
build() {
Column() {
Button("TimePickerDialog")
.margin(20)
.onClick(() => {
TimePickerDialog.show({
backgroundColor: 'rgb(204, 226, 251)',
backgroundBlurStyle: BlurStyle.NONE,
shadow: ShadowStyle.OUTER_FLOATING_SM,
onAccept: (value: TimePickerResult) => {
// Set selectTime to the time when the OK button is clicked. In this way, when the dialog box is displayed again, the selected time is the time when the operation was confirmed last time.
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute)
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
}
}
})
})
}.width('100%')
}
}
Example 7: Setting the Start Time
This example demonstrates how to set the start time for the time picker dialog box.
// xxx.ets
@Entry
@Component
struct TimePickerDialogExample {
private selectTime: Date = new Date('2022-07-22T08:50:00')
build() {
Column() {
Button("TimePickerDialog")
.margin(20)
.onClick(() => {
TimePickerDialog.show({
useMilitaryTime: false,
selected: this.selectTime,
format: TimePickerFormat.HOUR_MINUTE_SECOND,
start: new Date('2022-07-22T08:30:00'),
onAccept: (value: TimePickerResult) => {
// Set selectTime to the time when the OK button is clicked. In this way, when the dialog box is displayed again, the selected time is the time when the operation was confirmed last time.
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute)
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
}
}
})
})
}.width('100%')
}
}
Example 8: Setting the End Time
This example demonstrates how to set the end time for the time picker dialog box.
// xxx.ets
@Entry
@Component
struct TimePickerDialogExample {
private selectTime: Date = new Date('2022-07-22T08:50:00')
build() {
Column() {
Button("TimePickerDialog")
.margin(20)
.onClick(() => {
TimePickerDialog.show({
useMilitaryTime: false,
selected: this.selectTime,
format: TimePickerFormat.HOUR_MINUTE_SECOND,
end: new Date('2022-07-22T15:20:00'),
onAccept: (value: TimePickerResult) => {
// Set selectTime to the time when the OK button is clicked. In this way, when the dialog box is displayed again, the selected time is the time when the operation was confirmed last time.
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute)
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
}
}
})
})
}.width('100%')
}
}
Example 9: Enabling the AM/PM Indicator to Automatically Switch Based on the Hour in 12-hour Format
This example demonstrates how to enable AM/PM indicator to automatically switch based on the hour in 12-hour format using enableCascade.
// xxx.ets
@Entry
@Component
struct TimePickerDialogExample {
private selectTime: Date = new Date('2022-07-22T08:00:00')
build() {
Column() {
Button("TimePickerDialog")
.margin(20)
.onClick(() => {
TimePickerDialog.show({
useMilitaryTime: false,
selected: this.selectTime,
enableCascade:true,
onAccept: (value: TimePickerResult) => {
// Set selectTime to the time when the OK button is clicked. In this way, when the dialog box is displayed again, the selected time is the time when the operation was confirmed last time.
if (value.hour != undefined && value.minute != undefined) {
this.selectTime.setHours(value.hour, value.minute)
console.info("TimePickerDialog:onAccept()" + JSON.stringify(value))
}
}
})
})
}.width('100%')
}
}
你可能感兴趣的鸿蒙文章
- 所属分类: 后端技术
- 本文标签:
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦