Utilisez l'API audio fallback pour donner dynamiquement la priorité à l'audio en fonction de la qualité du réseau.
Notes : Les OTPublisherKit.audioFallbackEnabled sera obsolète. Veuillez utiliser la propriété OTPublisherKitSettings.publisherAudioFallbackEnabled et OTPublisherKitSettings.subscriberAudioFallbackEnabled à la place.
Enabling and disabling audio-only fallback
Pour activer le repli audio de l'éditeur, définissez le paramètre OTPublisherKitSettings.publisherAudioFallbackEnabled lors de la création de l'éditeur.
// Enable publisher audio fallback
let publisherSettings = OTPublisherSettings()
publisherSettings.publisherAudioFallbackEnabled = YES
// Enable publisher audio fallback and disable subscriber audio fallback
let publisherSettings = OTPublisherSettings()
publisherSettings.publisherAudioFallbackEnabled = YES
publisherSettings.subscriberAudioFallbackEnabled = NO
// Enable subscriber audio fallback and disable publisher audio fallback
let publisherSettings = OTPublisherSettings()
publisherSettings.publisherAudioFallbackEnabled = NO
publisherSettings.subscriberAudioFallbackEnabled = YES
Pour activer et désactiver le repli audio de l'abonné (pour tous les abonnés au flux), définissez le paramètre OTPublisherKitSettings.subscriberAudioFallbackEnabled lors de la création de l'éditeur. Le repli audio de l'abonné n'est pris en charge que dans les sessions acheminées (sessions qui utilisent la propriété Routeur vidéo multimédia de Vonage). Le repli audio de l'abonné est activé par défaut (dans les sessions acheminées) pour les flux dont la source est une caméra vidéo.
Audio fallback events
Lorsque le repli audio de l'éditeur est activé, le PublisherKitDelegate enverra les messages suivants concernant les événements liés au repli audio de l'éditeur :
[OTPublisherKitDelegate publisherVideoDisableWarning:]- Appelé lorsque l'éditeur détermine que la qualité du flux s'est dégradée et que la vidéo sera désactivée si la qualité se dégrade davantage.[OTPublisherKitDelegate publisherVideoDisableWarningLifted:]- Appelé lorsque l'éditeur détermine que la qualité du flux s'est améliorée au point que la vidéo désactivée ne représente plus un risque immédiat.[OTPublisherKitDelegate publisherVideoDisabled:reason:]- Appelé lorsque l'éditeur détermine que la qualité du flux s'est dégradée et que le transport vidéo sortant a été désactivé. Remarque : lorsque la vidéo est désactivée, l'éditeur continue d'afficher la vidéo de l'éditeur (telle que l'image de la caméra) dans l'interface utilisateur du client de publication.[OTPublisherKitDelegate publisherVideoEnabled:reason:]- Appelé avec la raison "quality" lorsque l'éditeur détermine que la qualité du flux s'est améliorée et que le transport vidéo sortant a été réactivé. Par exemple, le code suivant gère les événements associés (afin que vous puissiez fournir vos propres notifications à l'interface utilisateur) :
func publisherVideoDisableWarning(_ publisher: OTPublisherKit) {
// Custom action — for example, add custom UI notification
}
func publisherVideoDisableWarningLifted(_ publisher: OTPublisherKit) {
// Custom action — for example, remove custom UI notification
}
func publisherVideoDisabled(_ publisher: OTPublisherKit, reason: OTPublisherVideoEventReason) {
// Custom action — for example, add custom UI notification
}
func publisherVideoEnabled(_ publisher: OTPublisherKit, reason: OTPublisherVideoEventReason) {
// Custom action — for example, remove custom UI notification
}
Du point de vue de l'abonné, les événements suivants indiquent que le repli audio s'est produit. Bien que ces événements soient liés à l'abonné ils peuvent se produire à la fois en raison du repli audio de l'abonné et en conséquence du repli audio de l'éditeur. En d'autres termes, la différence entre le repli audio de l'éditeur et celui de l'abonné est la suivante la différence entre le repli audio de l'éditeur et de l'abonné est que, dans le cas de l'éditeur, le client de publication peut déclencher le repli audio sur la base de son propre flux. sur la base de sa propre dégradation du flux, ce qui explique pourquoi des événements supplémentaires sont envoyés du côté de l'éditeur. Pour le repli audio de l'abonné le Video Media Router de Vonage évalue la dégradation du réseau affectant l'abonné. Dans les deux cas, lors d'un repli audio de l'éditeur ou de l'abonné, les événements de l'abonné sont envoyés. les événements de l'abonné sont toujours envoyés pour indiquer que le récepteur a bénéficié d'un repli audio.
Lorsque le repli audio de l'abonné se produit, le SubscriberKitDelegate enverra les messages suivants concernant les événements liés au repli audio de l'abonné :
[OTSubscriberKitDelegate subscriberVideoDisableWarning:] - Appelé lorsqu'il est déterminé que la qualité du flux s'est dégradée et que la vidéo sera désactivée si la qualité se dégrade davantage.
[OTSubscriberKitDelegate subscriberVideoDisableWarningLifted:] - Appelé lorsqu'il est déterminé que la qualité du flux s'est améliorée au point que la vidéo désactivée ne constitue pas un risque immédiat.
[OTSubscriberKitDelegate subscriberVideoDisabled:reason:] - Appelé lorsqu'il est déterminé que la qualité du flux s'est dégradée et que le transport vidéo sortant a été désactivé. Remarque : lorsque la vidéo est désactivée, l'abonné continue d'afficher la vidéo de l'abonné (telle que l'image de la caméra) dans l'interface utilisateur du client de publication.
[OTSubscriberKitDelegate subscriberVideoEnabled:reason:] - Appelé avec le motif "quality" lorsqu'il est déterminé que la qualité du flux s'est améliorée et que le transport vidéo sortant a été réactivé.
Par exemple, le code suivant gère les événements connexes (afin que vous puissiez fournir vos propres notifications à l'interface utilisateur) :
func subscriberVideoDisableWarning(_ subscriber: OTSubscriberKit) {
// Custom action — for example, add custom UI notification
}
func subscriberVideoDisableWarningLifted(_ subscriber: OTSubscriberKit) {
// Custom action — for example, remove custom UI notification
}
func subscriberVideoDisabled(_ subscriber: OTSubscriberKit, reason: OTSubscriberVideoEventReason) {
// Custom action — for example, add custom UI notification
}
func subscriberVideoEnabled(_ subscriber: OTSubscriberKit, reason: OTSubscriberVideoEventReason) {
// Custom action — for example, remove custom UI notification
}