代理提醒(ArkTS)
功能介绍
应用退到后台或进程终止后,仍然有一些提醒用户的定时类通知,为满足此类功能场景,系统提供了代理提醒的能力。当应用退至后台或进程终止后,系统会代理应用做定时提醒。当前支持的提醒类型包括:倒计时、日历和闹钟。
约束与限制
- 个数限制:一个普通应用支持最多30个有效提醒,一个系统应用支持最多10000个有效提醒。整个系统最多支持12000个有效提醒。
说明:
当到达设置的提醒时间点时,通知中心会弹出相应提醒。若未点击提醒上的关闭/CLOSE按钮,则代理提醒是有效/未过期的;若点击了关闭/CLOSE按钮,则代理提醒过期。
当代理提醒是周期性提醒时,如设置每天提醒,无论是否点击关闭/CLOSE按钮,代理提醒都是有效的。
- 跳转限制:点击提醒通知后跳转的应用必须是申请代理提醒的本应用。
与相关Kit的关系
- 当到达设置的提醒时间点后,代理提醒使用Notification Kit发布通知,通知会显示在通知中心,通知样式请参考Notification Kit通知样式中文本类型。
模拟器支持情况
从API version 20开始,本能力支持模拟器开发。
接口说明
以下是代理提醒的相关接口,下表均以Promise形式为例,更多接口及使用方式请见后台代理提醒文档。
表1 主要接口
| 接口名 | 描述 |
|---|---|
| publishReminder(reminderReq: ReminderRequest): Promise<number> | 发布后台代理提醒。 |
| cancelReminder(reminderId: number): Promise<void> | 取消指定id的代理提醒。 |
| getValidReminders(): Promise<Array<ReminderRequest>> | 获取当前应用设置的所有有效(未过期)的代理提醒。 |
| cancelAllReminders(): Promise<void> | 取消当前应用设置的所有代理提醒。 |
| addNotificationSlot(slot: NotificationSlot): Promise<void> | 添加通知渠道。 |
| removeNotificationSlot(slotType: notification.SlotType): Promise<void> | 删除指定的通知渠道类型。 |
开发步骤
申请权限
申请ohos.permission.PUBLISH_AGENT_REMINDER权限,配置方式请参阅声明权限。
请求通知授权
请求通知授权。获得用户授权后,才能使用代理提醒功能。
功能开发
-
导入模块。
import { reminderAgentManager } from '@kit.BackgroundTasksKit'; import { notificationManager } from '@kit.NotificationKit'; import { BusinessError } from '@kit.BasicServicesKit'; -
定义目标提醒代理。开发者根据实际需要,选择定义如下类型的提醒。
-
定义倒计时实例。
let timer: reminderAgent.ReminderRequestTimer = { reminderType: reminderAgent.ReminderType.REMINDER_TYPE_TIMER, // 提醒类型为倒计时类型 ringDuration: Constant.REMINDER_DURATION, title: context.resourceManager.getStringSync($r('app.string.timer').id), // 指明提醒标题, "app.string.timer"资源文件中的value值为"计时器" content: context.resourceManager.getStringSync($r('app.string.countdown_close').id), // 指明提醒内容, "app.string.countdown_close"资源文件中的value值为"计时器已结束" wantAgent: { // // 点击提醒通知后跳转的目标UIAbility信息 pkgName: 'com.example.reminderagentmanager', abilityName: 'EntryAbility' }, notificationId: 100, // 指明提醒使用的通知的ID号,相同ID号的提醒会覆盖 slotType: notificationManager.SlotType.CONTENT_INFORMATION, // 指明提醒的Slot类型 triggerTimeInSeconds: this.countdownTime }; -
定义日历实例。
let calendar: reminderAgent.ReminderRequestCalendar = { reminderType: reminderAgent.ReminderType.REMINDER_TYPE_CALENDAR, // 提醒类型为日历类型 dateTime: { // 指明提醒的目标时间 year: date.getFullYear(), month: date.getUTCMonth() + 1, day: date.getDate(), hour: date.getHours(), minute: date.getMinutes(), }, actionButton: // 设置弹出的提醒通知信息上显示的按钮类型和标题 [{ title: context.resourceManager.getStringSync($r('app.string.calendar_close').id), // "app.string.calendar_close"资源文件中的value值为"关闭日历提醒" type: reminderAgent.ActionButtonType.ACTION_BUTTON_TYPE_CLOSE }], // 点击提醒通知后跳转的目标UIAbility信息 wantAgent: { pkgName: 'com.example.reminderagentmanager', abilityName: 'EntryAbility' }, ringDuration: Constant.REMINDER_DURATION, // 指明响铃时长(单位:秒) title: context.resourceManager.getStringSync($r('app.string.calendar').id), // 指明提醒标题, "app.string.calendar"资源文件中的value值为"日历" content: context.resourceManager.getStringSync($r('app.string.calendar_reach').id), // 指明提醒内容, "app.string.calendar_reach"资源文件中的value值为"日历提醒时间到了" slotType: notificationManager.SlotType.CONTENT_INFORMATION // 指明提醒的Slot类型 } -
定义闹钟实例。
let alarm: reminderAgent.ReminderRequestAlarm = { reminderType: reminderAgent.ReminderType.REMINDER_TYPE_ALARM, // 提醒类型为闹钟类型 hour: time.hour, // 指明提醒的目标时刻 minute: time.minute, // 指明提醒的目标分钟 actionButton: // 设置弹出的提醒通知信息上显示的按钮类型和标题 [ { title: context.resourceManager.getStringSync($r('app.string.alarm_clock_close').id), // "app.string.alarm_clock_close"资源文件中的value值为"关闭闹钟" type: reminderAgent.ActionButtonType.ACTION_BUTTON_TYPE_CLOSE }, { title: context.resourceManager.getStringSync($r('app.string.alarm_clock_postpone').id), // "app.string.alarm_clock_postpone"资源文件中的value值为"推迟闹钟" type: reminderAgent.ActionButtonType.ACTION_BUTTON_TYPE_SNOOZE } ], slotType: notificationManager.SlotType.CONTENT_INFORMATION, // 指明提醒的Slot类型 ringDuration: Constant.REMINDER_DURATION, // 指明响铃时长(单位:秒) wantAgent: { // 点击提醒通知后跳转的目标UIAbility信息 pkgName: 'com.example.reminderagentmanager', abilityName: 'EntryAbility' }, title: context.resourceManager.getStringSync($r('app.string.alarm_clock').id), // 指明提醒标题, "app.string.alarm_clock"资源文件中的value值为"闹钟" content: context.resourceManager.getStringSync($r('app.string.alarm_clock_reach').id), // 指明提醒内容, "app.string.alarm_clock_reach"资源文件中的value值为"闹钟时间已到" snoozeTimes: 0, // 指明延迟提醒次数 timeInterval: 0, // 执行延迟提醒间隔(单位:秒) daysOfWeek: [] // 指明每周哪几天需要重复提醒 }
-
-
发布相应的提醒代理。代理发布后,应用即可使用后台代理提醒功能。
let reminderId: number = await reminderAgent.publishReminder( this.calendarReminders[index].reminderRequestCalendar!); Logger.info(TAG, `publish reminder result: id is ${reminderId}`); this.calendarReminders[index].reminderId = reminderId; // 保存发布的提醒ID -
根据需要删除提醒任务。
Logger.info(TAG, `cancel reminder id is ${this.calendarReminders[index].reminderId}`) await reminderAgent.cancelReminder(this.calendarReminders[index].reminderId);
相关实例
基于代理提醒,有以下相关实例可供参考: