为通话应用创建通话样式通知

在 Android 12.0(API 级别 31)及更高版本中,系统提供了 CallStyle 通知模板,用于区分通话通知与 其他类型的通知。使用此模板可创建来电或正在通话通知。该模板支持大型通知,其中包含来电者信息和必要的操作,例如接听或拒接来电。

由于来电和正在通话是高优先级事件,因此这些通知在通知抽屉式通知栏中具有最高优先级。这种排名还让系统能够将这些优先处理的通话转接到其他设备。

CallStyle 通知模板包含以下必要操作:

  • 针对来电的接听拒接
  • 针对正在通话的挂断
  • 针对通话过滤的接听挂断

此样式的操作以按钮形式显示,系统会自动添加适当的图标和文本。不支持手动为按钮添加标签。 如需详细了解通知设计原则,请参阅 通知

带有标签按钮的通话样式通知
图 1.来电和正在通话的 CallStyle 模板。

必要操作以 intent 形式传递,例如以下部分中的 hangupIntentanswerIntent。这些都是对系统维护的令牌的引用。令牌是一个轻量级对象,可以在不同的应用和进程之间传递。系统负责管理令牌的生命周期,并确保即使创建该令牌的应用不再运行,PendingIntent 仍可用。当您向另一个应用提供 PendingIntent 时,您即授予该应用执行指定操作(例如拒接或接听)的权限。 即使创建 intent 的应用未运行,也会授予此权限。如需了解详情,请参阅 PendingIntent的参考文档。

从 Android 14(API 级别 34)开始,您可以将通话通知配置为不可关闭。为此,请通过 Notification.Builder#setOngoing(true)使用带有 Notification.FLAG_ONGOING_EVENTCallStyle通知。

以下示例展示了如何将各种方法与 CallStyle 通知搭配使用。

// Create a new call, setting incoming caller.
val incomingCaller = Person.Builder()
    .setName("Jane Doe")
    .setImportant(true)
    .build()

来电

使用 forIncomingCall() 方法为来电创建通话样式通知。

// For demonstrative purposes only, should use a well-defined Intents.
val contentIntent =
    PendingIntent.getActivity(context, 0, Intent(), PendingIntent.FLAG_IMMUTABLE)
val declineIntent =
    PendingIntent.getActivity(context, 0, Intent(), PendingIntent.FLAG_IMMUTABLE)
val hangupIntent = PendingIntent.getActivity(context, 0, Intent(), PendingIntent.FLAG_IMMUTABLE)
val answerIntent = PendingIntent.getActivity(context, 0, Intent(), PendingIntent.FLAG_IMMUTABLE)
// Create a call style notification for an incoming call.
val builderForIncomingCall = NotificationCompat.Builder(context, CHANNEL_ID)
    .setContentIntent(contentIntent)
    .setSmallIcon(R.drawable.ic_logo)
    .setStyle(
        NotificationCompat.CallStyle.forIncomingCall(incomingCaller, declineIntent, answerIntent))
    .addPerson(incomingCaller)

正在通话

使用 forOngoingCall() 方法为正在通话创建通话样式通知。

// Create a call style notification for an ongoing call.
val builderForOngoingCall = NotificationCompat.Builder(context, CHANNEL_ID)
    .setContentIntent(contentIntent)
    .setSmallIcon(R.drawable.ic_logo)
    .setStyle(
        NotificationCompat.CallStyle.forOngoingCall(callerAtOtherEnd, hangupIntent))
    .addPerson(caller)

过滤通话

使用 forScreeningCall() 方法为过滤通话创建通话样式通知。

// Create a call style notification for screening a call.
val builder = NotificationCompat.Builder(context, CHANNEL_ID)
    .setContentIntent(contentIntent)
    .setSmallIcon(R.drawable.ic_logo)
    .setStyle(
        NotificationCompat.CallStyle.forScreeningCall(caller, hangupIntent, answerIntent))
    .addPerson(caller)

提供对更多 Android 版本的兼容性

将 API 版本 30 或更低版本中的 CallStyle 通知与前台服务相关联,以便为它们分配在 API 级别 31 或更高版本中获得的较高排名。此外,API 版本 30 或更低版本中的 CallStyle 通知可以通过使用 setColorized() 方法将通知标记为 彩色,从而获得类似的排名。

将 Telecom API 与 CallStyle 通知搭配使用。如需了解详情,请参阅 Telecom 框架概览