This tutorial will cover the basics of using the WebRTC package.
The namespace specifies Unity.WebRTC
.
using UnityEngine;
using Unity.WebRTC;
Create a local peer and get RTCDataChannel
. Use RTCDataChannel
to enable binary data transmission. Register OnOpen
and OnClose
callbacks to run a process when RTCDataChannel
starts or finishes. Set the OnMessage
callback to receive messages.
// Create local peer
var localConnection = new RTCPeerConnection();
var sendChannel = localConnection.CreateDataChannel("sendChannel");
sendChannel.OnOpen = handleSendChannelStatusChange;
sendChannel.OnClose = handleSendChannelStatusChange;
Create a remote peer and set the OnDataChannel
callback.
// Create remote peer
var remoteConnection = new RTCPeerConnection();
remoteConnection.OnDataChannel = ReceiveChannelCallback;
An ICE (Interactive Connectivity Establishment) exchange is required to establish a peer connection. Once the potential communication paths for all peers have been discovered, OnIceCandidate
is called. Use callbacks to call AddIceCandidate
on each peer to register potential paths.
localConnection.OnIceCandidate = e => { !string.IsNullOrEmpty(e.candidate)
|| remoteConnection.AddIceCandidate(e); }
remoteConnection.OnIceCandidate = e => { !string.IsNullOrEmpty(e.candidate)
|| localConnection.AddIceCandidate(e); }
SDP exchanges happen between peers. CreateOffer
creates the initial Offer SDP. After getting the Offer SDP, both the local and remote peers set the SDP. Be careful not to mix up SetLocalDescription
and SetRemoteDescription
during this exchange.
Once the Offer SDP is set, call CreateAnswer
to create an Answer SDP. Like the Offer SDP, the Answer SDP is set on both the local and remote peers.
var op1 = localConnection.CreateOffer();
yield return op1;
var op2 = localConnection.SetLocalDescription(ref op1.desc);
yield return op2;
var op3 = remoteConnection.SetRemoteDescription(ref op1.desc);
yield return op3;
var op4 = remoteConnection.CreateAnswer();
yield return op4;
var op5 = remoteConnection.setLocalDescription(op4.desc);
yield return op5;
var op6 = localConnection.setRemoteDescription(op4.desc);
yield return op6;
When SDP exchanges happen between peers, ICE exchanges begin. Use the OnIceConnectionChange
callback to check the ICE connection status.
localConnection.OnIceConnectionChange = state => {
Debug.Log(state);
}
When the ICE exchange is finished, OnDataChannel
is called and a one-way peer Data Channel is created.
Register the OnMessage
callback and describe the procedure for when a message is received.
RTCDataChannel receiveChannel;
void ReceiveChannelCallback(RTCDataChannel channel)
{
receiveChannel = channel;
receiveChannel.OnMessage = HandleReceiveMessage;
}
When both peers' RTCDataChannel
is open, it's possible to exchange messages. string
or byte[]
message types can be sent.
void SendMessage(string message)
{
sendChannel.Send(message);
}
void SendBinary(byte[] bytes)
{
sendChannel.Send(bytes);
}
When a message is received, the callback registered to OnMessage
is called. byte[]
type messages can be received, and when treated like character strings they are converted as shown below.
void HandleReceiveMessage(byte[] bytes)
{
var message = System.Text.Encoding.UTF8.GetString(bytes);
Debug.Log(message);
}
When finished, Close
method must be called for RTCDataChannel
and RTCPeerConnection
.
private void OnDestroy()
{
sendChannel.Close();
receiveChannel.Close();
localConnection.Close();
remoteConnection.Close();
}
This package provides sample scenes which demonstrate features like video/audio streaming. Please try them following this page.