Audio-Fallback
Verwenden Sie die Audio-Fallback-API, um Audio dynamisch in Abhängigkeit von der Netzwerkqualität zu priorisieren.
Die Audio-Fallback-Funktion sorgt dafür, dass Ihre Anrufe unabhängig von Verbindungsproblemen oder schlechten Netzwerkbedingungen für alle Teilnehmer weiterlaufen, indem das Video für den betroffenen Teilnehmer vorübergehend deaktiviert wird. Die Audio-Fallback-Funktion reagiert in Echtzeit auf die Netzwerkbedingungen und stellt sicher, dass die Teilnehmer auch bei schlechter Netzabdeckung nicht abspringen. Sobald sich die Bedingungen verbessern, wird der Videostream durch unsere Videowiederherstellungsfunktion wiederhergestellt.
Die Audio-Fallback-Funktionen des Herausgebers und des Teilnehmers sorgen gemeinsam für eine optimale Gesprächsqualität. Ein einzelner Teilnehmer kann auf eine reine Audioverbindung zurückgreifen (wenn nur die Bedingungen des Teilnehmers dies rechtfertigen) oder ein Herausgeber kann bei schlechten Netzbedingungen auf eine reine Audioverbindung zurückgreifen.
Wenn die Funktionen zum Veröffentlichen und Abonnieren von Audio-Fallback aktiviert sind, sendet das SDK Ereignisse aus, um veränderte Qualitätsbedingungen anzuzeigen. Sie können diese Ereignisse verwenden, um Benachrichtigungen im Client auszulösen, oder das SDK kann die Standard-Benachrichtigungen der Benutzeroberfläche anzeigen.
Teilnehmer-Audio-Fallback
Die Subscriber-Audio-Fallback-Funktion verbessert die Gesprächsqualität, indem sie eingehende Videoströme automatisch abschaltet, was zu einem reinen Audiomodus führt, wenn sich die Netzbedingungen auf der Teilnehmerseite verschlechtern. Andere Clients werden unabhängig von den Netzwerkbedingungen des Teilnehmers weiterhin Video empfangen. Diese Funktion wird über den Vonage Video Media Router abgewickelt und ist nur in gerouteten Sitzungen verfügbar. Siehe dieDokumente zur Sitzungserstellung um den Unterschied zwischen gerouteten und weitergeleiteten Sitzungen zu verstehen.
Publisher Audio Fallback
Die Audio-Fallback-Funktion des Herausgebers verbessert die Gesprächsqualität, indem ein Herausgeber in den reinen Audiomodus wechselt, wenn die Netzwerkbedingungen des Herausgeber-Clients kein Video unterstützen. Sobald sich die Netzwerkbedingungen verbessern, schaltet der Publisher wieder auf Video um.
Die Publisher Audio Fallback-Funktion wird sowohl in weitergeleiteten als auch in gerouteten Sitzungen unterstützt (siehe Der Vonage Video Media Router und die Medienmodi).
Die Audio-Fallback-Funktionen des Herausgebers umfassen Verbesserungen zur Überwachung der Bandbreite und Überlastung eines veröffentlichten Streams. Der Verleger priorisiert die Audiokommunikation und greift auf Audio zurück, wenn die Überlastung der Bandbreite keine Videokommunikation zulässt.
Mit der Audio-Fallback-Funktion des Herausgebers erhält der Herausgeber-Client eine Qualitätsrückmeldung (über Paketverlust, Bandbreite und Überlastung) vom Teilnehmer (bei einer weitergeleiteten Sitzung) oder vom Vonage Video Media Router (bei einer gerouteten Sitzung).
Interpretation von Audio-Fallback-Ereignissen von Herausgebern und Teilnehmern im Hinblick auf eine Verschlechterung der Netzqualität
Publisher- und Subscriber-Audio-Fallback-Ereignisse zeigen nicht direkt an, welcher Endpunkt von einer Netzwerkverschlechterung betroffen ist. Stattdessen spiegeln sie zwei unterschiedliche Perspektiven auf die Netzwerkqualität wider: die Sicht des Herausgebers auf seine eigenen Statistiken und die aggregierte Sicht des Vonage Video Media Routers.
In weitergeleiteten Sitzungen wird nur der Audio-Fallback des Herausgebers unterstützt. Obwohl Fallback-Ereignisse vom Herausgeber ausgehen, bedeutet dies nicht unbedingt, dass beim Herausgeber Netzwerkprobleme auftreten. Überlastungsmetriken werden Ende-zu-Ende berechnet und werden sowohl vom Herausgeber als auch vom Teilnehmer beeinflusst.
Bei gerouteten Sitzungen werden sowohl Publisher- als auch Subscriber-Fallback unterstützt. Da der Vonage Video Media Router verschiedene Peer-Verbindungsübergänge durchführen oder in hybriden Konfigurationen arbeiten kann, kann es schwierig sein, die genaue Quelle der Verschlechterung allein anhand von Fallback-Ereignissen zu bestimmen. Als Faustregel gilt, dass die Verschlechterung auf der Seite des Teilnehmers liegt. Wenn Publisher Audio Fallback aktiviert ist und der Client ein Fallback-Ereignis empfängt, das unmittelbar von einemStream aktualisiert Ereignis wenn der Videokanal deaktiviert ist, kann auch - oder ausschließlich - der Herausgeber betroffen sein. Der Publisher-Fallback kann jedoch immer noch durch die vom Abonnenten gemeldeten Metriken beeinflusst werden.
Audio-Fallback verwenden
Die Client-SDKs enthalten Ereignisse für Publisher- und Subscriber-Audio-Fallback. Diese Ereignisse zeigen an, wenn das Publisher- oder Subscriber-Video aktiviert oder deaktiviert ist und wenn eine Warnung für das deaktivierte Video aufgrund von Audio-Fallback (und Video-Wiederherstellung) vorliegt.
Sie können das Audio-Fallback aktivieren und deaktivieren, wenn Sie einen Stream veröffentlichen.
Use the audio fallback API to dynamically prioritize audio in response to network quality.
Note: The audioFallbackEnabled prop of the OTPublisher component will be deprecated. Please use the audioFallback.subscriber setting instead.
Enabling and disabling audio-only fallback
Set the audioFallback property of the properties prop you pass into the OTPublisher component:
// Enable subscriber audio fallback (the default)
// and publisher audio fallback:
<OTPublisher
properties={{
audioFallback={
publisher: true,
},
}}
/>
});
// Enable publisher audio fallback and disable subscriber audio fallback:
<OTPublisher
properties={{
audioFallback: {
publisher: true,
subscriber: false,
},
}}
/>
// Enable subscriber audio fallback and disable publisher audio fallback:
<OTPublisher
properties={{
audioFallback: {
publisher: false,
subscriber: true,
},
}}
/>
// Disable both publisher audio fallback (the default)
// and subscriber audio fallback:
<OTPublisher
properties={{
audioFallback: {
subscriber: false,
},
}}
/>
The audioFallback object includes two Boolean properties:
publisher— Whether to enable (true) or disable (false) publisher audio fallback. With publisher audio fallback enabled, when the stream's quality has degraded significantly (for example, because of network conditions), the publisher disables video in order to preserve audio quality. The default isfalse(publisher audio fallback is disabled).subscriber— Whether to enable (true) or disable (false) subscriber audio fallback. This setting only applies in routed sessions (sessions that use the Vonage Video Media Router). Subscriber audio fallback is not supported in relayed sessions. With subscriber audio fallback enabled, when the Vonage Video Media Router determines that a stream's quality has degraded significantly for a specific subscriber, it disables the video in that subscriber in order to preserve audio quality. The default istrue(subscriber audio fallback is enabled). This setting replaces theaudioFallbackEnabledproperty, which will be deprecated.
Audio fallback events
When publisher audio fallback is enabled, callback methods of the OTPublisher component are invoked in response to changing quality conditions:
videoDisableWarning()— Called when the Publisher determines that the stream quality has degraded and the video will be disabled if the quality degrades more.videoDisableWarningLifted()— Called when the Publisher determines that the stream quality has improved to the point at which the video being disabled is not an immediate risk.videoDisabled()— Called when the Publisher determines that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Publisher still displays the publisher video (such as the camera image) in the publishing client's UI.videoEnabled()— Called with the reason property set to 'quality' when the Publisher determines that the stream quality has improved and outgoing video transport has been re-enabled.
For example the following code adds event listeners for audio fallback-related events (so that you can provide user interface notifications):
<OTPublisher
properties={{
audioFallback: {
publisher: true,
}
}}
eventHandlers={{
videoDisableWarning: () => {
// Add UI notification
},
videoDisableWarningLifted: () => {
// Adjust UI notification
},
videoDisabled: () => {
// Add UI notification
},
videoEnabled: () => {
// Remove UI notification
},
}}
/>
From the subscriber’s perspective, the following events indicate that audio fallback has occurred. Although these events are tied to the subscriber, they can occur both due to subscriber audio fallback and as a consequence of publisher audio fallback. In other words, the difference between publisher and subscriber audio fallback is that, in the publisher case, the publishing client may trigger the audio fallback based on its own stream degradation, which is why additional publisher-side events are dispatched. For subscriber audio fallback, the Vonage Video Media Router assesses network degradation affecting the subscriber. In both cases, upon publisher or subscriber audio fallback, subscriber events are always dispatched to indicate that audio fallback has occurred for the receiver.
The OTSubscriber component includes callback methods that are invoked based on events related to the video being enabled or disabled for the subscriber's stream:
videoEnabled() — Called when the video has been enabled after it was previously disabled.
videoDisabled() — Called when the video has been disabled. The reason property of the event object indicates why the video was disabled. (This event object is an VideoEnabledChangedEvent object.)
videoDisableWarning() — Called when it is determined that the stream quality has degraded and the video will be disabled if the quality degrades more. If the quality degrades further, the Subscriber disables the video and calls the videoDisabled() callback. This event may also be dispatched when using the publisher audio fallback feature if the publisher's stream quality if degraded.
videoDisableWarningLifted() — Called when video has been enabled after it was previously disabled.
The OTSubscriber videoDisableWarning() and videoDisableWarningLifted() callback methods are only invoked in sessions that use the Media Router (sessions with the media mode set to routed).
For example the following code adds event listeners for audio fallback-related events (so that you can provide user interface notifications):
<OTSubscriber
eventHandlers={{
videoDisableWarning: () => {
// Add UI notification
},
videoDisableWarningLifted: () => {
// Adjust UI notification
},
videoDisabled: () => {
// Add UI notification
},
videoEnabled: () => {
// Remove UI notification
},
}}
/>
Use the audio fallback API to dynamically prioritize audio in response to network quality.
Note: The audioFallbackEnabled property of the options passed into the OT.initPublisher() method will be deprecated. Please use the audioFallback.subscriber property of the options object instead.
Enabling and disabling audio-only fallback
When initializing the Publisher object, set the audioFallback property of the option you pass into the OT.initPublisher() method:
// Enable publisher audio fallback
const publisher = OT.initPublisher('target', {
audioFallback: {
publisher: true,
}
});
// Enable publisher audio fallback and disable subscriber audio fallback
const publisher = OT.initPublisher('target', {
audioFallback: {
publisher: true,
subscriber: false,
}
});
// Enable subscriber audio fallback and disable publisher audio fallback
const publisher = OT.initPublisher('target', {
audioFallback: {
publisher: false,
subscriber: true,
}
});
The audioFallback property of the options you pass into the OT.initPublisher() method includes two Boolean properties:
publisher— Whether to enable (true) or disable (false) publisher audio fallback. The default isfalse(publisher audio fallback is disabled).subscriber— Whether to enable (true) or disable (false) subscriber audio fallback. This setting only applies in routed sessions (sessions that use the Vonage Video Media Router). Subscriber audio fallback is not supported in relayed sessions. The default istrue(subscriber audio fallback is enabled). This setting replaces theaudioFallbackEnabledproperty, which will be deprecated.
Audio fallback events and UI indications
When publisher audio fallback is enabled, the Publisher object dispatches these events in response to changing quality conditions:
videoDisableWarning— Dispatched when the Publisher determines that the stream quality has degraded and the video will be disabled if the quality degrades more.videoDisableWarningLifted— Dispatched when the Publisher determines that the stream quality has improved to the point at which the video being disabled is not an immediate risk.videoDisabled— Dispatched when the Publisher determines that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Publisher still displays the publisher video (such as the camera image) in the publishing client's UI.videoEnabled— Dispatched with reason: 'quality' when the Publisher determines that the stream quality has improved and outgoing video transport has been re-enabled.
By default, the Publisher displays icons when the videoDisableWarning and videoDisabled events occur.
The style property of the options parameter for OT.initPublisher() now includes a videoDisabledDisplayMode property.
You can set the videoDisabledDisplayMode property to one of the following string values control how the default
user interface elements are displayed:
auto(the default) — The icons are automatically displayed when the video is disabled or in risk of being disabled due to poor stream quality.off— The icons are not displayed. You can display your own user interface notifications based on the events described above.on— The icons are automatically displayed when the video is disabled or in risk of being disabled due to poor stream quality.
For example the following code disables the default video disabled user interface elements, and handles the related events (so that you can provide your own user interface notifications):
// Enabled
const publisher = OT.initPublisher('target', {
audioFallback: {
publisher: true,
},
style: {
videoDisabledDisplayMode: 'off',
}
});
publisher.on({
videoDisableWarning: () => {
// Custom action — for example, add custom UI notification
},
videoDisableWarningLifted: () => {
// Custom action — for example, remove custom UI notification
},
videoDisabled: () => {
// Custom action — for example, add custom UI notification
},
videoEnabled: () => {
// Custom action — for example, remove custom UI notification
},
});
You can also set the videoDisabledDisplayMode style dynamically by calling the Publisher.setStyle() method:
publisher.setStyle('videoDisabledDisplayMode', 'off');
// Alternately:
publisher.setStyle({
videoDisabledDisplayMode: 'off',
// other styles ...
});
From the subscriber’s perspective, the following events indicate that audio fallback has occurred. Although these events are tied to the subscriber, they can occur both due to subscriber audio fallback and as a consequence of publisher audio fallback. In other words, the difference between publisher and subscriber audio fallback is that, in the publisher case, the publishing client may trigger the audio fallback based on its own stream degradation, which is why additional publisher-side events are dispatched. For subscriber audio fallback, the Vonage Video Media Router assesses network degradation affecting the subscriber. In both cases, upon publisher or subscriber audio fallback, subscriber events are always dispatched to indicate that audio fallback has occurred for the receiver.
A Subscriber object dispatches the following events related to the video being enabled or disabled for the subscriber's stream:
videoEnabled— Dispatched when the video has been enabled after it was previously disabled.videoDisabled— Dispatched when the video has been disabled. Thereasonproperty of the event object indicates why the video was disabled. (This event object is an VideoEnabledChangedEvent object.)videoDisableWarning— Dispatched when it is determined that the stream quality has degraded and the video will be disabled if the quality degrades more. If the quality degrades further, the Subscriber disables the video and dispatches a videoDisabled event. This event may also be dispatched when using the beta publisher audio fallback feature if the publisher's stream quality if degraded.videoDisableWarningLifted— The video has been enabled after it was previously disabled.
By default, the Subscriber displays a video disabled warning indicator and a video disabled indicator when the videoDisableWarning and videoDisableWarningLifted events are dispatched. You can disable the default display of the indicator by setting the videoDisabledDisplayMode style setting of the Subscriber object.
The following example uses the videoDisabledDisplayMode style setting to have the video disabled warning indicator and a video disabled indicator blink every one second when the videoDisableWarning and videoDisableWarningLifted events are dispatched:
const indicatorBlinker = new IndicatorBlinker(subscriber);
const IndicatorBlinker = function(subscriber) {
const timer;
const indicatorOn = false;
subscriber.on({
videoDisabled: function(event) {
start();
},
videoDisableWarning: function(event) {
start();
},
videoDisableWarningLifted: function(event) {
stop();
},
videoEnabled: function(event) {
stop();
}
});
const start = function() {
subscriber.setStyle('videoDisabledDisplayMode', 'on');
if (timer) {
clearInterval(timer);
}
timer = setInterval(function() {
if (indicatorOn) {
subscriber.setStyle('videoDisabledDisplayMode', 'off');
} else {
subscriber.setStyle('videoDisabledDisplayMode', 'on');
}
indicatorOn = !indicatorOn;
}, 1000);
indicatorOn = true;
};
const stop = function() {
if (timer) {
clearInterval(timer);
}
};
}
You can also set the videoDisabledDisplayMode style to 'off' and add your own user interface elements based on the videoDisableWarning, videoDisabled, videoDisableWarningLifted, and videoEnabled events.
Use the audio fallback API to dynamically prioritize audio in response to network quality.
Notes: The PublisherKit.setAudioFallbackEnabled() and PublisherKit.getAudioFallbackEnabled() methods will be deprecated. Please use the PublisherKit.Builder.publisherAudioFallbackEnabled() and PublisherKit.Builder.subscriberAudioFallbackEnabled() methods instead.
Enabling and disabling audio-only fallback
To enable publisher audio fallback, call the PublisherKit.Builder.publisherAudioFallbackEnabled() function when creating the publisher.
To enable and disable subscriber audio fallback (for all subscribers to the stream), call the PublisherKit.Builder.subscriberAudioFallbackEnabled() function when creating the publisher. Subscriber audio fallback is only supported in routed sessions (sessions that use the Vonage Video Media Router). Subscriber audio fallback is enabled by default (in routed sessions) for streams with a camera video source.
Audio fallback events
When publisher audio fallback is enabled, callback methods of the PublisherKit.VideoListener are invoked for publisher audio fallback-related events:
PublisherKit.VideoListener.onVideoDisableWarning()— Called when the Publisher determines that the stream quality has degraded and the video will be disabled if the quality degrades more.PublisherKit.VideoListener.onVideoDisableWarningLifted()— Called when the Publisher determines that the stream quality has improved to the point at which the video being disabled is not an immediate risk.PublisherKit.VideoListener.onVideoDisabled()— Called when the Publisher determines that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Publisher still displays the publisher video (such as the camera image) in the publishing client's UI.PublisherKit.VideoListener.onVideoEnabled()— Called with reason "quality" when the Publisher determines that the stream quality has improved and outgoing video transport has been re-enabled. For example the following code handles the related events (so that you can provide your own user interface notifications):
From the subscriber’s perspective, the following events indicate that audio fallback has occurred. Although these events are tied to the subscriber, they can occur both due to subscriber audio fallback and as a consequence of publisher audio fallback. In other words, the difference between publisher and subscriber audio fallback is that, in the publisher case, the publishing client may trigger the audio fallback based on its own stream degradation, which is why additional publisher-side events are dispatched. For subscriber audio fallback, the Vonage Video Media Router assesses network degradation affecting the subscriber. In both cases, upon publisher or subscriber audio fallback, subscriber events are always dispatched to indicate that audio fallback has occurred for the receiver.
When audio fallback occurs, callback methods of the SubscriberKit.VideoListener are invoked for subscriber audio fallback-related events:
SubscriberKit.VideoListener.onVideoDisableWarning() — Called when it is determined that the stream quality has degraded and the video will be disabled if the quality degrades more.
SubscriberKit.VideoListener.onVideoDisableWarningLifted() — Called when it is determined that the stream quality has improved to the point at which the video being disabled is not an immediate risk.
SubscriberKit.VideoListener.onVideoDisabled() — Called when it is determined that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Subscriber still displays the subscriber video (such as the camera image) in the publishing client's UI.
SubscriberKit.VideoListener.onVideoEnabled() — Called with reason "quality" when it is determined that the stream quality has improved and outgoing video transport has been re-enabled.
For example the following code handles the related events (so that you can provide your own user interface notifications):
Use the audio fallback API to dynamically prioritize audio in response to network quality.
Notes: The OTPublisherKit.audioFallbackEnabled property will be deprecated. Please use the OTPublisherKitSettings.publisherAudioFallbackEnabled and OTPublisherKitSettings.subscriberAudioFallbackEnabled properties instead.
Enabling and disabling audio-only fallback
To enable publisher audio fallback, set the OTPublisherKitSettings.publisherAudioFallbackEnabled property when creating the publisher.
// 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
To enable and disable subscriber audio fallback (for all subscribers to the stream), set the OTPublisherKitSettings.subscriberAudioFallbackEnabled property when creating the publisher. Subscriber audio fallback is only supported in routed sessions (sessions that use the Vonage Video Media Router). Subscriber audio fallback is enabled by default (in routed sessions) for streams with a camera video source.
Audio fallback events
When publisher audio fallback is enabled, the PublisherKitDelegate object will send the following messages pertaining to publisher audio fallback-related events:
[OTPublisherKitDelegate publisherVideoDisableWarning:]— Called when the Publisher determines that the stream quality has degraded and the video will be disabled if the quality degrades more.[OTPublisherKitDelegate publisherVideoDisableWarningLifted:]— Called when the Publisher determines that the stream quality has improved to the point at which the video being disabled is not an immediate risk.[OTPublisherKitDelegate publisherVideoDisabled:reason:]— Called when the Publisher determines that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Publisher still displays the publisher video (such as the camera image) in the publishing client's UI.[OTPublisherKitDelegate publisherVideoEnabled:reason:]— Called with reason "quality" when the Publisher determines that the stream quality has improved and outgoing video transport has been re-enabled. For example the following code handles the related events (so that you can provide your own user interface notifications):
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
}
From the subscriber’s perspective, the following events indicate that audio fallback has occurred. Although these events are tied to the subscriber, they can occur both due to subscriber audio fallback and as a consequence of publisher audio fallback. In other words, the difference between publisher and subscriber audio fallback is that, in the publisher case, the publishing client may trigger the audio fallback based on its own stream degradation, which is why additional publisher-side events are dispatched. For subscriber audio fallback, the Vonage Video Media Router assesses network degradation affecting the subscriber. In both cases, upon publisher or subscriber audio fallback, subscriber events are always dispatched to indicate that audio fallback has occurred for the receiver.
When subscriber audio fallback occurs, the SubscriberKitDelegate object will send the following messages pertaining to subscriber audio fallback-related events:
[OTSubscriberKitDelegate subscriberVideoDisableWarning:] — Called when it is determined that the stream quality has degraded and the video will be disabled if the quality degrades more.
[OTSubscriberKitDelegate subscriberVideoDisableWarningLifted:] — Called when it is determined that the stream quality has improved to the point at which the video being disabled is not an immediate risk.
[OTSubscriberKitDelegate subscriberVideoDisabled:reason:] — Called when it is determined that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Subscriber still displays the subscriber video (such as the camera image) in the publishing client's UI.
[OTSubscriberKitDelegate subscriberVideoEnabled:reason:] — Called with reason "quality" when it is determined that the stream quality has improved and outgoing video transport has been re-enabled.
For example the following code handles the related events (so that you can provide your own user interface notifications):
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
}
Use the audio fallback API to dynamically prioritize audio in response to network quality.
For conceptual information, see the audio fallback overview.
Notes: The OTPublisherKit.audioFallbackEnabled property will be deprecated. Please use the OTPublisherKitSettings.publisherAudioFallbackEnabled and OTPublisherKitSettings.subscriberAudioFallbackEnabled properties instead.
Enabling and disabling audio-only fallback
To enable publisher audio fallback, set the OTPublisherKitSettings.publisherAudioFallbackEnabled property when creating the publisher.
// Enable publisher audio fallback
OTPublisherKitSettings *settings = [[OTPublisherKitSettings alloc] init];
settings.publisherAudioFallbackEnabled = YES;
// Enable publisher audio fallback and disable subscriber audio fallback
OTPublisherKitSettings *settings = [[OTPublisherKitSettings alloc] init];
settings.publisherAudioFallbackEnabled = YES;
settings.subscriberAudioFallbackEnabled = NO;
// Enable subscriber audio fallback and disable publisher audio fallback
OTPublisherKitSettings *settings = [[OTPublisherKitSettings alloc] init];
settings.publisherAudioFallbackEnabled = NO;
settings.subscriberAudioFallbackEnabled = YES;
To enable and disable subscriber audio fallback (for all subscribers to the stream), set the OTPublisherKitSettings.subscriberAudioFallbackEnabled property when creating the publisher. Subscriber audio fallback is only supported in routed sessions (sessions that use the Vonage Video Media Router). Subscriber audio fallback is enabled by default (in routed sessions) for streams with a camera video source.
Audio fallback events
When publisher audio fallback is enabled, the PublisherKitDelegate object will send the following messages pertaining to publisher audio fallback-related events:
[OTPublisherKitDelegate publisherVideoDisableWarning:]— Called when the Publisher determines that the stream quality has degraded and the video will be disabled if the quality degrades more.[OTPublisherKitDelegate publisherVideoDisableWarningLifted:]— Called when the Publisher determines that the stream quality has improved to the point at which the video being disabled is not an immediate risk.[OTPublisherKitDelegate publisherVideoDisabled:reason:]— Called when the Publisher determines that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Publisher still displays the publisher video (such as the camera image) in the publishing client's UI.[OTPublisherKitDelegate publisherVideoEnabled:reason:]— Called with reason "quality" when the Publisher determines that the stream quality has improved and outgoing video transport has been re-enabled. For example the following code handles the related events (so that you can provide your own user interface notifications):
-(void) publisherVideoDisableWarning:(OTPublisherKit *)publisher videoDisableWarning {
// Custom action — for example, add custom UI notification
}
-(void) publisherVideoDisableWarningLifted:(OTPublisherKit *)publisher videoDisableWarningLifted {
// Custom action — for example, remove custom UI notification
}
-(void) publisherVideoDisabled:(OTPublisherKit *)publisher reason:(OTPublisherVideoEventReason)reason {
// Custom action — for example, add custom UI notification
}
-(void) publisherVideoEnabled:(OTPublisherKit *)publisher reason:(OTPublisherVideoEventReason)reason {
// Custom action — for example, remove custom UI notification
}
From the subscriber’s perspective, the following events indicate that audio fallback has occurred. Although these events are tied to the subscriber, they can occur both due to subscriber audio fallback and as a consequence of publisher audio fallback. In other words, the difference between publisher and subscriber audio fallback is that, in the publisher case, the publishing client may trigger the audio fallback based on its own stream degradation, which is why additional publisher-side events are dispatched. For subscriber audio fallback, the Vonage Video Media Router assesses network degradation affecting the subscriber. In both cases, upon publisher or subscriber audio fallback, subscriber events are always dispatched to indicate that audio fallback has occurred for the receiver.
When audio fallback occurs, the SubscriberKitDelegate object will send the following messages pertaining to subscriber audio fallback-related events:
[OTSubscriberKitDelegate subscriberVideoDisableWarning:] — Called when it is determined that the stream quality has degraded and the video will be disabled if the quality degrades more.
[OTSubscriberKitDelegate subscriberVideoDisableWarningLifted:] — Called when it is determined that the stream quality has improved to the point at which the video being disabled is not an immediate risk.
[OTSubscriberKitDelegate subscriberVideoDisabled:reason:] — Called when it is determined that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Subscriber still displays the subscriber video (such as the camera image) in the publishing client's UI.
[OTSubscriberKitDelegate subscriberVideoEnabled:reason:] — Called with reason "quality" when it is determined that the stream quality has improved and outgoing video transport has been re-enabled.
For example the following code handles the related events (so that you can provide your own user interface notifications):
-(void) subscriberVideoDisableWarning:(OTSubscriberKit *)subscriber videoDisableWarning {
// Custom action — for example, add custom UI notification
}
-(void) subscriberVideoDisableWarningLifted:(OTSubscriberKit *)subscriber videoDisableWarningLifted {
// Custom action — for example, remove custom UI notification
}
-(void) subscriberVideoDisabled:(OTSubscriberKit *)subscriber reason:(OTSubscriberVideoEventReason)reason {
// Custom action — for example, add custom UI notification
}
-(void) subscriberVideoEnabled:(OTSubscriberKit *)subscriber reason:(OTSubscriberVideoEventReason)reason {
// Custom action — for example, remove custom UI notification
}
Use the audio fallback API to dynamically prioritize audio in response to network quality.
Enabling and disabling audio-only fallback
To enable publisher audio fallback, set the Publisher.Builder.PublisherAudioFallback property when creating a Publisher object.
To enable and disable subscriber audio fallback (for all subscribers to the stream), call the Publisher.Builder.SubscriberAudioFallback property when creating a Publisher object. Subscriber audio fallback is only supported in routed sessions (sessions that use the Media Router). Subscriber audio fallback is enabled by default (in routed sessions) for streams with a camera video source.
Audio fallback events
When publisher audio fallback is enabled, the Publisher object dispatches audio fallback-related events:
Publisher.VideoDisableWarning— Sent when the Publisher determines that the stream quality has degraded and the video will be disabled if the quality degrades more. Publisher.VideoDisableWarningLifted — Sent when the Publisher determines that the stream quality has improved to the point at which the video being disabled is not an immediate risk.Publisher.VideoDisabled— Sent when the Publisher determines that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Publisher still displays the publisher video (such as the camera image) in the publishing client's UI.Publisher.VideoEnabled— Sent with reason set to "quality" when the Publisher determines that the stream quality has improved and outgoing video transport has been re-enabled.
For example the following code handles the related events (so that you can provide your own user interface notifications):
From the subscriber’s perspective, the following events indicate that audio fallback has occurred. Although these events are tied to the subscriber, they can occur both due to subscriber audio fallback and as a consequence of publisher audio fallback. In other words, the difference between publisher and subscriber audio fallback is that, in the publisher case, the publishing client may trigger the audio fallback based on its own stream degradation, which is why additional publisher-side events are dispatched. For subscriber audio fallback, the Vonage Video Media Router assesses network degradation affecting the subscriber. In both cases, upon publisher or subscriber audio fallback, subscriber events are always dispatched to indicate that audio fallback has occurred for the receiver.
When subscriber audio fallback is enabled, the Subscriber object dispatches audio fallback-related events:
Subscriber.VideoDisableWarning— Sent when it is determined that the stream quality has degraded and the video will be disabled if the quality degrades more. Subscriber.VideoDisableWarningLifted — Sent when it is determined that the stream quality has improved to the point at which the video being disabled is not an immediate risk.Subscriber.VideoDisabled— Sent when it is determined that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Subscriber still displays the subscriber video (such as the camera image) in the publishing client's UI.Subscriber.VideoEnabled— Sent with reason set to "quality" when it is determined that the stream quality has improved and outgoing video transport has been re-enabled.
For example the following code handles the related events (so that you can provide your own user interface notifications):
Use the audio fallback API to dynamically prioritize audio in response to network quality.
Notes: The otc_publisher_set_audio_fallback_enabled() and otc_publisher_get_audio_fallback_enabled() functions will be deprecated. Please use the otc_publisher_settings_set_publisher_audio_fallback_enabled and otc_publisher_settings_set_subscriber_audio_fallback_enabled instead.
Enabling and disabling audio-only fallback
To enable publisher audio fallback, call the otc_publisher_settings_set_publisher_audio_fallback_enabled() function.
To enable and disable subscriber audio fallback (for all subscribers to the stream), call the otc_publisher_settings_set_subscriber_audio_fallback_enabled() function. Subscriber audio fallback is only supported in routed sessions (sessions that use the Vonage Video Media Router). Subscriber audio fallback is enabled by default (in routed sessions) for streams with a camera video source.
Audio fallback events
When publisher audio fallback is enabled, callback functions in the otc_publisher_callbacks struct are invoked for publisher audio fallback-related events:
otc_publisher_callbacks.on_video_disable_warning()— Called when the Publisher determines that the stream quality has degraded and the video will be disabled if the quality degrades more.otc_publisher_callbacks.on_video_disable_warning_lifted()— Called when the Publisher determines that the stream quality has improved to the point at which the video being disabled is not an immediate risk.otc_publisher_callbacks.on_video_disabled()— Called when the Publisher determines that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Publisher still displays the publisher video (such as the camera image) in the publishing client's UI.otc_publisher_callbacks.on_video_enabled()— Called with reason "quality" when the Publisher determines that the stream quality has improved and outgoing video transport has been re-enabled. For example the following code handles the related events (so that you can provide your own user interface notifications):
From the subscriber’s perspective, the following events indicate that audio fallback has occurred. Although these events are tied to the subscriber, they can occur both due to subscriber audio fallback and as a consequence of publisher audio fallback. In other words, the difference between publisher and subscriber audio fallback is that, in the publisher case, the publishing client may trigger the audio fallback based on its own stream degradation, which is why additional publisher-side events are dispatched. For subscriber audio fallback, the Vonage Video Media Router assesses network degradation affecting the subscriber. In both cases, upon publisher or subscriber audio fallback, subscriber events are always dispatched to indicate that audio fallback has occurred for the receiver.
When audio fallback occurs, callback functions in the otc_subscriber_callbacks struct are invoked for subscriber audio fallback-related events:
otc_subscriber_callbacks.on_video_disable_warning()— Called when the Subscriber determines that the stream quality has degraded and the video will be disabled if the quality degrades more.otc_subscriber_callbacks.on_video_disable_warning_lifted()— Called when the Subscriber determines that the stream quality has improved to the point at which the video being disabled is not an immediate risk.otc_subscriber_callbacks.on_video_disabled()— Called when the Subscriber determines that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Subscriber still displays the subscriber video (such as the camera image) in the publishing client's UI.otc_subscriber_callbacks.on_video_enabled()— Called with reason "quality" when the Subscriber determines that the stream quality has improved and outgoing video transport has been re-enabled.
For example the following code handles the related events (so that you can provide your own user interface notifications):
Use the audio fallback API to dynamically prioritize audio in response to network quality.
Notes: The otc_publisher_set_audio_fallback_enabled() and otc_publisher_get_audio_fallback_enabled() functions will be deprecated. Please use the otc_publisher_settings_set_publisher_audio_fallback_enabled and otc_publisher_settings_set_subscriber_audio_fallback_enabled instead.
Enabling and disabling audio-only fallback
To enable publisher audio fallback, call the otc_publisher_settings_set_publisher_audio_fallback_enabled() function.
To enable and disable subscriber audio fallback (for all subscribers to the stream), call the otc_publisher_settings_set_subscriber_audio_fallback_enabled() function. Subscriber audio fallback is only supported in routed sessions (sessions that use the Vonage Video Media Router). Subscriber audio fallback is enabled by default (in routed sessions) for streams with a camera video source.
Audio fallback events
When publisher audio fallback is enabled, callback functions in the otc_publisher_callbacks struct are invoked for publisher audio fallback-related events:
otc_publisher_callbacks.on_video_disable_warning()— Called when the Publisher determines that the stream quality has degraded and the video will be disabled if the quality degrades more.otc_publisher_callbacks.on_video_disable_warning_lifted()— Called when the Publisher determines that the stream quality has improved to the point at which the video being disabled is not an immediate risk.otc_publisher_callbacks.on_video_disabled()— Called when the Publisher determines that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Publisher still displays the publisher video (such as the camera image) in the publishing client's UI.otc_publisher_callbacks.on_video_enabled()— Called with reason "quality" when the Publisher determines that the stream quality has improved and outgoing video transport has been re-enabled. For example the following code handles the related events (so that you can provide your own user interface notifications):
From the subscriber’s perspective, the following events indicate that audio fallback has occurred. Although these events are tied to the subscriber, they can occur both due to subscriber audio fallback and as a consequence of publisher audio fallback. In other words, the difference between publisher and subscriber audio fallback is that, in the publisher case, the publishing client may trigger the audio fallback based on its own stream degradation, which is why additional publisher-side events are dispatched. For subscriber audio fallback, the Vonage Video Media Router assesses network degradation affecting the subscriber. In both cases, upon publisher or subscriber audio fallback, subscriber events are always dispatched to indicate that audio fallback has occurred for the receiver.
When audio fallback occurs, the callback functions in the otc_subscriber_callbacks struct are invoked for subscriber audio fallback-related events:
otc_subscriber_callbacks.on_video_disable_warning()— Called when it is determined that the stream quality has degraded and the video will be disabled if the quality degrades more.otc_subscriber_callbacks.on_video_disable_warning_lifted()— Called when it is determined that the stream quality has improved to the point at which the video being disabled is not an immediate risk.otc_subscriber_callbacks.on_video_disabled()— Called when it is determined that the stream quality has degraded and the outgoing video transport has been disabled. Note: while the video is disabled, the Subscriber still displays the subscriber video (such as the camera image) in the publishing client's UI.otc_subscriber_callbacks.on_video_enabled()— Called with reason "quality" when it is determined that the stream quality has improved and outgoing video transport has been re-enabled.
For example the following code handles the related events (so that you can provide your own user interface notifications):