Keine Beschreibung

Michelle Bu da45d4f4d6 merge in crash fixes. fixes #93; fixes #95 vor 11 Jahren
bin 3d4ec9bc66 fix supports vor 12 Jahren
deps b6783ea13e Bump reliable vor 11 Jahren
dist da45d4f4d6 merge in crash fixes. fixes #93; fixes #95 vor 11 Jahren
docs 93fc4931b2 Update reliable doc vor 11 Jahren
examples ccd80612ae false by default vor 11 Jahren
lib da45d4f4d6 merge in crash fixes. fixes #93; fixes #95 vor 11 Jahren
test 4d6f655823 Remove most old tests vor 12 Jahren
.gitignore 36291b993a #45 .gitignore bower vor 12 Jahren
.gitmodules e65704ab15 use public submodule url for reliable vor 12 Jahren
LICENSE 332f2d486f license vor 12 Jahren
Makefile ea9a3207cb submodules, gitignore, make vor 12 Jahren
README.md 046b70b221 Update README.md vor 12 Jahren
changelog.md 3949c23634 0.3.1 vor 11 Jahren
package.json 611a106192 Update package.json vor 11 Jahren

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

var getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
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

var getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
peer.on('call', function(call) {
  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