需求是任何时候都能发送自定义通知,AlarmManager 可以发送定时任务,但是在低电量,或者长时间息屏后,可能无法收到定时任务,就像 worker 一样。当然用户通过手动清理最近任务,杀死进城后,AlarmManager 更无法收到定时任务。我记得不错的话,Android 无法像苹果一样做本地定时通知吧?定制终端除外,不过不知道在支持 Google service Framework 的设备上是否支持随时能收到的本地通知?
1
kop1989smurf 2022-11-30 10:25:45 +08:00
本地 service 必然不行,因为 doze 模式。( https://developer.android.com/training/monitoring-device-state/doze-standby?hl=zh-cn )
有个思路是定时任务上传服务器,之后利用推送平台,进行针对 ID 的消息推送。这也是 Android 官方推荐的方式。 |
2
FATEQiang OP @kop1989smurf 我也是这样想的,客户如果必须要通知这样的消息,只有利用在线推送了,毕竟保活就直接交给平台。否则只有用 calendar 日历来做,但是又无法弹窗自定义通知,因为无法改系统日历的 UI 和逻辑
|
3
shily 2022-11-30 10:32:29 +08:00
不研究一下闹钟怎么实现的吗?
|
4
kop1989smurf 2022-11-30 10:33:16 +08:00
@FATEQiang #2 是的,除非定制 ROM 给某个 app 跳过 doze 模式的权限,但这就超出了普通 app 的职责范围。
如果必须自定义通知+定时,几乎只有使用推送平台一条路。google 也是推荐使用 FCM 进行下游消息传递。 |
6
RightHand 2022-11-30 10:41:48 +08:00 via Android
申请电量无限制
|
8
wairdell 2022-11-30 13:44:56 +08:00
可以试试日历提醒
|
10
piku 2022-11-30 22:49:08 +08:00 via Android
如果是系统级推送通道(比如 mipush 或 hwpush )接收并弹出通知并不依赖 app 是否后台运行。重复通知可能还是依赖云端定时复推
|