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

当应用在录音界面收到推送通知并被用户点击时,系统默认会启动新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) {
    // 通过 Ev

entBus / 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()
}

⚠️ 关键注意事项:

  • 避免在 onMessageReceived() 中直接启动 Activity(尤其当目标 Activity 已在栈顶);应始终通过主线程 UI 组件触发跳转;
  • 使用 ActivityManager.getRunningTasks() 已被弃用,推荐通过 ActivityLifecycleCallbacks 或 ProcessLifecycleOwner 监听前台 Activity;
  • 录音服务建议采用前台 Service(startForeground())+ Notification(不可清除)双重保障,即使用户切出 App 仍可持续运行;
  • 若业务允许,可支持“后台继续录音 + 推送静默处理”,即点击通知仅跳转,录音服务不中断(需合理管理音频焦点与资源竞争)。

该方案已在多个音视频社交类应用(如 Intercom 的语音留言模块)中验证有效:既杜绝了无感知中断,又赋予用户完全掌控权,真正实现「功能不妥协,体验有温度」。