No Description

Michelle Bu 166eb8de1e Update README.md 12 years ago
bin 3d4ec9bc66 fix supports 12 years ago
deps 78ae5e0eed finished \o/ 12 years ago
dist 602db8de7c INTEROP 12 years ago
docs 292681d74f fork 12 years ago
examples e64bde1dce all use remote 0.3 12 years ago
lib 602db8de7c INTEROP 12 years ago
test 4d6f655823 Remove most old tests 12 years ago
.gitignore 36291b993a #45 .gitignore bower 12 years ago
.gitmodules e65704ab15 use public submodule url for reliable 12 years ago
LICENSE 332f2d486f license 12 years ago
Makefile ea9a3207cb submodules, gitignore, make 12 years ago
README.md 166eb8de1e Update README.md 12 years ago
changelog.md 9821d3e35a version/date 12 years ago
package.json 8433a2fd18 Version bump 12 years ago

README.md

PeerJS: peer-to-peer in the browser

PeerJS provides a complete, configurable, and easy-to-use peer-to-peer API built on top of WebRTC, supporting both WebRTC data channels and media streams.

##http://peerjs.com

Include the library

<script src="http://cdn.peerjs.com/0.3/peer.js"></script>

Peer

var peer = new Peer('thing1', {key: 'myapikey'}); // You can omit the ID if you want to get a random one from the server.

/** Data connections. */

peer.on('connection', function(connection) {
  connection.on('data', function(data){
    // Will print 'hi!'
    console.log(data);
  });
});

/** Media calls. */

var getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
peer.on('call', function(call) {
  getUserMedia({video: true, audio: true}, function(stream) {
    call.on('stream', function(stream) {
      // Show stream in some <video> element.
    });
    call.answer(stream); // Answer any call with an A/V stream.
  }, function(err) {
    console.log(err);
  });
});

Connecting peer

var peer = new Peer('thing2', {key: 'myapikey'}); // You can omit the ID if you want to get a random one from the server.

/** Data connections. */

var connection = peer.connect('thing1');
connection.on('open', function() {
  connection.send('hi!'); // Send 'hi!' when the data connection opens.
});

/** Media calls. */

var getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
getUserMedia({video: true, audio: true}, function(stream) {
  var call = peer.call('thing1', stream);
  call.on('stream', function(stream) {
    // Show stream in some <video> element.
  });
}, function(err) {
  console.log(err);
});

Documentation

Browser compatibility status

PeerServer

Discuss PeerJS on our Google Group

Changelog