如何在用户点击推送通知时避免中断当前录音会话

在 android 应用中,当用户处于音频录制界面时,若点击系统推送通知导致跳转至其他 activity,易造成录音中断、状态丢失。本文提供一套兼顾用户体验与业务连续性的解决方案:动态拦截通知、前台交互确认、会话保护机制。

在移动应用开发中,前台任务的连续性(如音频录制、视频通话、表单填写)常因后台推送通知的强制跳转而被意外中断。尤其当用户点击通知触发 PendingIntent 启动新 Activity 时,系统默认会销毁或暂停当前 Activity,导致录音资源未释放、状态未保存,最终引发“会话丢失”。

✅ 推荐实践:分层防护 + 用户知情确认

1. 主动清理历史通知,避免干扰

进入录音界面前,清空所有待处理的通知,防止旧通知误触:

fun clearNotifications() {
    val notificationManager = getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
    notificationManager.cancelAll()
}

调用时机建议放在 RecordingActivity.onResume() 或 onStart() 中,确保每次回到前台时环境干净。

2. 智能拦截新通知,改走前台交互

在 FirebaseMessagingService.onMessageReceived() 中判断当前前台 Activity 是否为录音页(可通过 ActivityManager 或更推荐的 ProcessLifecycleOwner + 自定义 LifecycleObserver 实现):

override fun onMessageReceived(remoteMessage: RemoteMessage) {
    if (isRecordingActivityInForeground()) {
        // 不发系统通知,改为向 RecordingActivity 发送本地事件(如 LiveData / EventBus / LocalBroadcast)
        recordingUiEvent.postValue(remoteMessage.notification?.body ?: "")
    } else {
        // 正常展示通知
        showSystemNotification(remoteMessage)
    }
}

3. 录音界面内嵌轻量级

通知 Widget

在 RecordingActivity 布局中添加一个可折叠/浮动的提示条(如 MaterialCardView),显示推送内容,并绑定点击事件:



    
    

点击后弹出 AlertDialog 明确告知风险:

btnViewPush.setOnClickListener {
    AlertDialog.Builder(this)
        .setTitle("切换页面将停止录音")
        .setMessage("当前正在录音,跳转后录音将立即终止且无法恢复。是否继续?")
        .setPositiveButton("继续") { _, _ ->
            startActivity(Intent(this, TargetActivity::class.java))
            stopRecording() // 主动释放 MediaRecorder/AudioRecord
        }
        .setNegativeButton("取消", null)
        .show()
}

⚠️ 注意事项与增强建议

  • 不要依赖 onPause() 做关键保存:Android 可能在 onPause() 后直接杀进程,录音数据应采用“边录边存临时文件”策略;
  • 使用 Foreground Service + Notification 保活:若需长时间录音,务必启动前台服务并展示持续通知(符合 Android 9+ 后台限制);
  • 状态持久化兜底:在 onStop() 中保存当前录音时长、文件路径、用户意图等元数据,便于返回时恢复或续录;
  • 兼容性提醒:ActivityManager.getRunningTasks() 已被弃用,推荐使用 ActivityCompat.isActivityRoot(this) 或 Jetpack ProcessLifecycleOwner 判断前台状态。

该方案已在 Intercom 等成熟 SDK 中验证落地——它不牺牲通知到达率,也不妥协核心任务稳定性,而是将“中断决策权”交还用户,真正实现有感知、可控制、不丢失的多任务体验。