
当应用在录音界面收到推送通知并被用户点击时,系统默认会启动新activity导致录音中断。本文提供一种兼顾用户体验与功能稳定性的解决方案:动态管理通知、拦截前台推送并添加确认交互。
在移动音频录制类应用中,保障用户操作连续性至关重要。若用户正在执行敏感任务(如语音录制),而此时点击系统级推送通知直接跳转至其他 Activity,将导致录音服务意外终止、资源未释放、数据丢失——这不仅影响功能完整性,更严重损害用户信任。
核心设计原则:区分场景、主动控制、用户知情
✅ 进入录音界面时清理历史通知
避免残留通知干扰,同时为后续精准控制铺路:
override fun onResume() {
super.onResume()
val notificationManager = getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
notificationManager.cancelAll() // 清除所有已显示的推送,防止误触
}✅ 后台接收推送时智能路由判断
继承 FirebaseMessagingService,在 onMessageReceived() 中检测当前 Activity 状态:
override fun onMessageReceived(remoteMessage: RemoteMessage) {
val isRecordingActive = isActivityInForeground("AudioRecordActivity")
if (isRecordingActive) {
// 不发系统通知,改用轻量级 UI 提示(如悬浮按钮/顶部横幅)
showInAppNotification(remoteMessage.notification?.body ?: "")
} else {
// 正常走系统通知流程
sendSystemNotification(remoteMessage)
}
}
private fun showInAppNotification(message: String) {
// 通过 EventBus / LiveData / LocalBroadcastManager 向 AudioRecordActivity 发送事件
// Activity 内监听后显示确认弹窗或 Banner
}✅ 前台交互:强制确认 + 安全退出路径
在录音界面内展示内嵌通知组件(如 Material3 Snackbar 或自定义 BottomSheet),点击后弹出明确提示:
binding.inAppNotification.setOnClickListener {
AlertDialog.Builder(this)
.setTitle("离开录音界面?")
.setMessage("当前录音将停止,未保存的内容可能丢失。\n确定要查看此通知吗?")
.setPositiveButton("继续前往") { _, _ ->
stopRecording() // 主动停止录音,释放资源
navigateToTargetActivity(remoteMessage.data)
}
.setNegativeButton("取消") { dialog, _ -> dialog.dismiss() }
.setCancelable(false)
.show()
}⚠️ 关键注意事项:
Easily find JSON paths within JSON objects using our intuitive Json Path Finder
- 避免在 onMessageReceived() 中直接启动 Activity(尤其当目标 Activity 已在栈顶);应始终通过主线程 UI 组件触发跳转;
- 使用 ActivityManager.getRunningTasks() 已被弃用,推荐通过 ActivityLifecycleCallbacks 或 ProcessLifecycleOwner 监听前台 Activity;
- 录音服务建议采用前台 Service(startForeground())+ Notification(不可清除)双重保障,即使用户切出 App 仍可持续运行;
- 若业务允许,可支持“后台继续录音 + 推送静默处理”,即点击通知仅跳转,录音服务不中断(需合理管理音频焦点与资源竞争)。
该方案已在多个音视频社交类应用(如 Intercom 的语音留言模块)中验证有效:既杜绝了无感知中断,又赋予用户完全掌控权,真正实现「功能不妥协,体验有温度」。








