Dodawanie powiadomień do aplikacji do multimediów

Gdy tworzysz aplikację do multimediów, która przetwarza dźwięk lub obraz, do odpowiednich kanałów powiadomień. Ten mają dostęp do tych przydatnych funkcji:

  • mają priorytet powiadomień,
  • są nie do zamknięcia,
  • Używanie atrybutów audio jako dzwonków

Za pomocą NotificationChannel.Builder skonfiguruj dwa kanały powiadomień: jeden do połączeń przychodzących, a drugiej – aktywnych.

internal companion object {
    const val TELECOM_NOTIFICATION_ID = 200
    const val TELECOM_NOTIFICATION_ACTION = "telecom_action"
    const val TELECOM_NOTIFICATION_INCOMING_CHANNEL_ID = "telecom_incoming_channel"
    const val TELECOM_NOTIFICATION_ONGOING_CHANNEL_ID = "telecom_ongoing_channel"

    private val ringToneUri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_RINGTONE)
}

Aby wyświetlać powiadomienie wszędzie i zezwolić na odtwarzanie dźwięku przez ustaw wysoką ważność kanału powiadomień przychodzących.

val incomingChannel = NotificationChannelCompat.Builder(
        TELECOM_NOTIFICATION_INCOMING_CHANNEL_ID,
        NotificationManagerCompat.IMPORTANCE_HIGH,
    ).setName("Incoming calls")
        .setDescription("Handles the notifications when receiving a call")
        .setVibrationEnabled(true).setSound(
            ringToneUri,
            AudioAttributes.Builder()
                .setContentType(AudioAttributes.CONTENT_TYPE_SONIFICATION)
                .setLegacyStreamType(AudioManager.STREAM_RING)
                .setUsage(AudioAttributes.USAGE_NOTIFICATION_RINGTONE).build(),
        ).build()

Tylko aktywne połączenia wymagają ustawienia ważności na poziomie domyślnym. Użyj postępuj zgodnie ze stylem połączeń przychodzących, aby umożliwić otrzymywanie powiadomień o połączeniach przychodzących nie można zamknąć.

val ongoingChannel = NotificationChannelCompat.Builder(
        TELECOM_NOTIFICATION_ONGOING_CHANNEL_ID,
        NotificationManagerCompat.IMPORTANCE_DEFAULT,
    )
    .setName("Ongoing calls")
    .setDescription("Displays the ongoing call notifications")
    .build()

Aby rozwiązać problemy z zablokowaniem urządzenia podczas połączenia przychodzącego: użyć powiadomienia pełnoekranowego do wyświetlenia aktywności, aby użytkownik mógł odebrać połączenie.

// on the notification
val contentIntent = PendingIntent.getActivity(
    /* context = */ context,
    /* requestCode = */ 0,
    /* intent = */ Intent(context, TelecomCallActivity::class.java),
    /* flags = */ PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE,
)

Instrukcje znajdziesz w artykule Tworzenie powiadomienia o stylu połączenia dla aplikacji do wykonywania połączeń. za pomocą CallStyle do odróżniania powiadomień o połączeniach od innych typów powiadomień powiadomienia.