跳过内容

Android

在 Android 上,插件会发布一个高优先级的 incoming-call 通知,并在平台和用户设置允许时可以弹出一个全屏活动。

插件清单已经包含:

<uses-permission android:name="android.permission.POST_NOTIFICATIONS" />
<uses-permission android:name="android.permission.USE_FULL_SCREEN_INTENT" />

安装后, cap sync 足以将该配置合并到主应用中。

在登陆或使用来电展示前,调用这些方法:

import { IncomingCallKit } from '@capgo/capacitor-incoming-call-kit';
await IncomingCallKit.requestPermissions();
await IncomingCallKit.requestFullScreenIntentPermission();
  • requestPermissions() 在 Android 13 及以上版本请求通知权限
  • requestFullScreenIntentPermission() 在需要时打开 Android 14 及以上版本的全屏意图设置页面
import { IncomingCallKit } from '@capgo/capacitor-incoming-call-kit';
await IncomingCallKit.showIncomingCall({
callId: 'call-42',
callerName: 'Ada Lovelace',
appName: 'Capgo Phone',
timeoutMs: 45_000,
android: {
channelId: 'calls',
channelName: 'Incoming Calls',
showFullScreen: true,
isHighPriority: true,
accentColor: '#0F766E',
},
});

Android 专属选项

标题:Android 专属选项
  • channelId通知渠道标识
  • channelName用户可见的渠道名称
  • showFullScreen请求全屏活动
  • isHighPriority: 保持通知足够打扰以产生铃声流
  • accentColor: 适配通知表面的颜色
  • ringtoneUri: 指向一个自定义的 Android 铃声资源或 URI
  • 全屏展示是尽力而为的。如果设备或用户设置阻止它,Android仍然会显示来电通知。
  • 超时处理是尽力而为的。插件跟踪 timeoutMs 并发射 callTimedOut,但您的后端仍应在其侧重新协调丢失的电话。
  • 接受、拒绝和结束动作通过 Capacitor 监听器反馈给您的应用程序,以便您的应用程序可以加入或清理真实的呼叫会话。
标题:推荐生产模型

使用 Android 推送或您的呼叫 SDK 进行传输,然后让该插件处理原生呼叫 UI 的最后一英里。将这些责任放在插件外面:

  • FCM 注册和令牌管理
  • 媒体会话生命周期
  • 后端调用状态
  • 重试和错过呼叫业务逻辑