Cross-channel media stream relay
Some special scenarios require cross-channel media stream forwarding functionality. Video SDK enables you to relay the media stream of a host, from a source channel, to multiple target channels simultaneously. This functionality allows you to realize the following interactions:
-
The hosts publish and receive each other's audio and video streams while engaging in cross-channel real-time interaction.
-
The audience receive all audio and video streams from hosts and watch multiple hosts interact at the same time.
Due to its real-time and interactive nature, this feature enriches live broadcasts and game-play, It is especially suitable for live scenes such as co-hosting PK and online choir. It provides the audience with a better viewing experience, while bringing more traffic and revenue to the hosts.
Cross-channel media stream relay is included in Agora's policy of 10,000 free minutes every month. For usage beyond the free quota, please refer to Pricing.
Prerequisites
- Ensure that you have implemented the SDK quickstart in your project.
- Contact technical support to activate the cross-channel media stream relay feature.
Implement cross-channel media stream relay
The following figure shows the workflow you implement to facilitate cross-channel media stream relay:
To implement cross-channel media stream relay in your app, take the following steps:
-
Start cross-channel media stream relay
After joining a channel, call
startOrUpdateChannelMediaRelay
to configure the source and target channel information and start forwarding a media stream.information- Best practice is to set the UID of the source channel to
0
, allowing the SDK to assign a random UID. - The source channel token in
srcChannelInfo
should be different from the one used when joining the source channel. Generate a new token using the source channel name anduid = 0
. - For the destination channel, set the uid to
0
, to allow the SDK to assign a randomuid
, or specify auid
, ensuring that it is different from all UIDs in the target channel.
- Best practice is to set the UID of the source channel to
-
Update media stream relay channels
To forward the stream to multiple target channels or exit the current forwarding channel after staring channel media relay, call
startOrUpdateChannelMediaRelay
again to add or remove target channels for forwarding.NoteThe updated configuration completely replaces the previous configuration.
-
Pause or resume media stream relay
To pause forwarding the media stream to all target channels, call
pauseAllChannelMediaRelay
.To resume forwarding the media stream to all target channels, call
resumeAllChannelMediaRelay
. -
Stop cross-channel media stream relay
To stop forwarding the media stream, call
stopChannelMediaRelay
. When forwarding stops, the host exits all target channels.NoteIf this method fails, call
leaveChannel
to leave the channel and stop cross-channel media stream relay. -
Monitor cross-channel media stream status
During cross-channel media stream relay, the SDK reports changes in the status of media stream relay through the
onChannelMediaRelayStateChanged
callback. Implement the relevant business logic based on the status codes.
Development considerations
- In live broadcast scenarios, only users with the role of a host can call
startOrUpdateChannelMediaRelay
to initiate cross-channel media stream forwarding. startOrUpdateChannelMediaRelay
must be called after successfully joining a channel, or it will result in an error.- Within a single channel, multiple hosts can forward the media stream. A single host can forward the media stream to up to 6 target channels.
- This feature does not support String type
uid
. If you need to use the cross-channel co-hosting feature, you must also use Integer typeuid
in regular co-hosting; otherwise, the cross-channel co-hosting feature will not work properly.
Reference
This section contains content that completes the information on this page, or points you to documentation that explains other aspects to this product.
Status codes
The main media stream forwarding states and their corresponding status codes are as follows:
Media stream forwarding status | status code |
---|---|
The source channel starts transmitting data to the target channel. | RELAY_STATE_RUNNING (2) and RELAY_OK (0) |
Cross-channel media stream forwarding encounters an exception. You can troubleshoot based on the error code. | RELAY_STATE_FAILURE (3) |
Media stream forwarding has stopped. | RELAY_STATE_IDLE (0) and RELAY_OK (0) |
Sample project
Agora provides an open-source HostAcrossChannels sample project for your reference. Download the project or view the source code for a more detailed example.