Aucune description

Michelle Bu e34b89fee9 Merge pull request #217 from peers/michelle-reconnect il y a 11 ans
bin 3d4ec9bc66 fix supports il y a 12 ans
deps e520030639 Update utf8 compatible by default binarypack il y a 11 ans
dist 0df19e5ca9 Do not abort if already disconnected. Emit events consistently. il y a 11 ans
docs 70b0861488 Update docs il y a 11 ans
examples 48cd966763 more logging il y a 11 ans
lib 0df19e5ca9 Do not abort if already disconnected. Emit events consistently. il y a 11 ans
test d8d82371a6 added adapter.js to the tests il y a 11 ans
.gitignore 36291b993a #45 .gitignore bower il y a 12 ans
.gitmodules e65704ab15 use public submodule url for reliable il y a 12 ans
LICENSE 582e4de3e4 update copyright year il y a 11 ans
Makefile ea9a3207cb submodules, gitignore, make il y a 12 ans
README.md 214a14cc10 navigator #98 il y a 11 ans
changelog.md 7ad9494c9e 0.3.8 il y a 11 ans
package.json 7ad9494c9e 0.3.8 il y a 11 ans

README.md

PeerJS: Simple peer-to-peer with WebRTC

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

http://peerjs.com

Setup

Include the library

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

Create a Peer
Get a free API key. Your id only needs to be unique to the namespace of your API key.

var peer = new Peer('pick-an-id', {key: 'myapikey'}); 
// You can pick your own id or omit the id if you want to get a random one from the server.

Data connections

Connect

var conn = peer.connect('another-peers-id');
conn.on('open', function(){
  conn.send('hi!');
});

Receive

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

Media calls

Call

navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
navigator.getUserMedia({video: true, audio: true}, function(stream) {
  var call = peer.call('another-peers-id', stream);
  call.on('stream', function(remoteStream) {
    // Show stream in some <video> element.
  });
}, function(err) {
  console.log('Failed to get local stream' ,err);
});

Answer

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

Links

Documentation / API Reference

WebRTC Browser compatibility status

PeerServer

Discuss PeerJS on our Google Group

Changelog