Realtime working WebRTC Experiments and Demos
It is a repository of uniquely experimented WebRTC demos; written by Muaz Khan; contributed by you and the community!
No special requirement! Just Chrome (for desktop and android) or Firefox!
These demos/experiments are entirely client-side; i.e. no server installation needed! (for basic webpages only!)
Following signaling gateways can work with each and every WebRTC Experiment!
- RecordRTC: WebRTC audio/video recording / Demo
- Pre-recorded media streaming
- WebRTC one-way video broadcasting
- Group video sharing / video-conferencing / Latest Demo
- Group file sharing / Latest Demo
- Group text chat / Latest Demo
- Using RTCDataChannel
- Using Firebase
- A realtime chat using RTCDataChannel
- A realtime chat using Firebase
Demos using DataChannel.js
- Multi-Session Establishment
- File Sharing + Text Chat
- All-in-One test
- Video Conferencing
- Video Broadcasting
- Audio Conferencing
- Join with/without camera
- Screen Sharing
- One-to-One file sharing
- Manual session establishment + extra data transmission
- Manual session establishment + extra data transmission + video conferencing
- Users ejection and presence detection
- Customizing Bandwidth
- RTCMultiConnection-v1.3 testing demo
in-Page / One-Page / Client Side |
---|
Text chat using RTCDataChannel APIs |
Simple video chat |
Sharing video - using socket.io for signaling |
Sharing video - using WebSockets for signaling |
A few documents for newbies and beginners |
---|
RTCPeerConnection Documentation |
RTCMultiConnection Documentation |
DataChannel Documentation |
How to use RTCPeerConnection.js? |
RTCDataChannel for Beginners |
How to use RTCDataChannel? - single code for both canary and nightly |
WebRTC for Beginners: A getting stared guide! |
WebRTC for Newbies |
How to write video-conferencing application using WebRTC? |
How to broadcast files using RTCDataChannel APIs? |
WebRTC Signaling Concepts |
<script src="https://webrtc-experiment.appspot.com/DataChannel.js"></script>
var channel = new DataChannel('channel-name');
channel.onopen = function(e) {};
channel.onmessage = function(e) {};
// share with all participants
channel.send(file || data || 'text');
// Direct messages using user-ids
channel.userid = 'muazkh';
channel.channels['muazkh'].send(file || data || 'text');
<script src="https://webrtc-experiment.appspot.com/RTCMultiConnection-v1.4.js"></script>
var connection = new RTCMultiConnection();
// session is included in v1.3 and higher releases
connection.session = {
audio: true,
video: true
};
// bandwidth is included in v1.3 and higher releases
connection.bandwidth = {
audio: 50,
video: 256,
data: 1638400
};
// framerate is included in v1.4 and higher releases
connection.framerate = {
minptime: 10,
maxptime: 60
};
connection.onstream = function (e) {
if (e.type === 'local') mainVideo.src = e.blobURL; // or URL.createObjectURL(e.stream)
if (e.type === 'remote') document.body.appendChild(e.mediaElement);
}
// searching/connecting pre-created session
connection.connect('session-id');
// to create/open a new session
connection.open('session-id');
<script src="https://webrtc-experiment.appspot.com/RTCall.js"></script>
var call = new RTCall();
call.onincomingcall = function(caller) {
call.receive(caller.receiverid);
};
call.oncustomer = function(customer) {
call.call(customer.callerid);
};
Use WebSocket over Node.js for signaling
In ui.js
files you can find openSocket
method; or in all libraries; you can find openSignalingChannel
method.
var SIGNALING_SERVER = 'ws://' + document.domain + ':8888/';
openSignalingChannel: function(config) {
config.channel = config.channel || 'default-channel';
var websocket = new WebSocket(SIGNALING_SERVER);
websocket.channel = config.channel;
websocket.onopen = function() {
websocket.push(JSON.stringify({
open: true,
channel: config.channel
}));
if (config.callback)
config.callback(websocket);
};
websocket.onmessage = function(event) {
config.onmessage(JSON.parse(event.data));
};
websocket.push = websocket.send;
websocket.send = function(data) {
websocket.push(JSON.stringify({
data: data,
channel: config.channel
}));
};
}
Your server-side node.js code looks like this:
io.sockets.on('connection', function (socket) {
socket.on('message', function (data) {
socket.broadcast.emit('message', data);
});
});
And to override openSignalingChannel
on the client side:
connection.openSignalingChannel = function(callback) {
return io.connect().on('message', callback);
};
It means that now:
- No dynamic namespace or channel is required.
- A single socket connection is opened for the lifetime of the webpage
Use Socket.io over Node.js for signaling!
Note: These signaling implementations were designed for old WebRTC experiments. You can still use them with each new experiment; however it is not recommended. It is recommended to use signaling implementation from previous section.
// openSignalingChannel or openSocket!
openSignalingChannel: function(config) {
var SIGNALING_SERVER = 'http://domain.com:8888/';
var channel = config.channel || this.channel || 'default-channel';
var sender = Math.round(Math.random() * 60535) + 5000;
io.connect(SIGNALING_SERVER).emit('new-channel', {
channel: channel,
sender : sender
});
var socket = io.connect(SIGNALING_SERVER + channel);
socket.channel = channel;
socket.on('connect', function () {
if (config.callback) config.callback(socket);
});
socket.send = function (message) {
socket.emit('message', {
sender: sender,
data : message
});
};
socket.on('message', config.onmessage);
}
For a ready-made socket.io over node.js implementation; visit this link.
Remember, You must link firebase.js file before using below code:
openSignalingChannel: function (config) {
var SIGNALING_SERVER = 'https://chat.firebaseIO.com/';
var channel = config.channel || this.channel || 'WebRTC-Experiment';
var firebase = new Firebase(SIGNALING_SERVER + channel);
firebase.channel = channel;
firebase.on('child_added', function (data) {
config.onmessage && config.onmessage(data.val());
});
firebase.send = function (data) {
this.push(data);
};
config.onopen && setTimeout(config.onopen, 1);
firebase.onDisconnect().remove();
return firebase;
}
How to use RecordRTC?
<script src="https://webrtc-experiment.appspot.com/RecordRTC.js"></script>
How to record video using RecordRTC?
var recorder = RecordRTC({
video: HTMLVideoElement
});
/* start recording video */
recorder.recordVideo();
/* stop recording video and save recorded file to disk */
recorder.stopVideo(function(recordedFileURL) {
window.open(recordedFileURL);
});
How to record GIF using RecordRTC?
<script src="https://webrtc-experiment.appspot.com/gif-recorder.js"></script>
var recorder = RecordRTC({
video: HTMLVideoElement
});
/* start recording gif */
recorder.recordGIF();
/* stop recording gif and save recorded file to disk */
recorder.stopGIF(function(gifURL) {
window.open(gifURL);
});
How to record audio using RecordRTC?
var recorder = RecordRTC({
stream: MediaStream || LocalMediaStream
});
/* start recording audio */
recorder.recordAudio();
/* stop recording audio and save recorded file to disk */
recorder.stopAudio(function(recordedFileURL) {
window.open(recordedFileURL);
});
WebRTC Experiments works fine on following web-browsers:
Browser | Support |
---|---|
Firefox | Stable / Aurora / Nightly |
Google Chrome | Stable / Canary / Beta / Dev |
Android | Chrome Beta |
WebRTC Experiments are released under MIT licence . Copyright (c) 2013 Muaz Khan.