Nav apraksta

Michelle Bu c80acbb9f6 Update package.json to 0.3.4 11 gadi atpakaļ
bin 3d4ec9bc66 fix supports 12 gadi atpakaļ
deps 9a83845604 Update binarypack 11 gadi atpakaļ
dist c80acbb9f6 Update package.json to 0.3.4 11 gadi atpakaļ
docs cbc0b18d85 Version bump, changelog, and update docs 11 gadi atpakaļ
examples f1f4b23571 Update js-binarypack 11 gadi atpakaļ
lib 3eed4a0dc2 Chunking for Chrome only 11 gadi atpakaļ
test 4d6f655823 Remove most old tests 12 gadi atpakaļ
.gitignore 36291b993a #45 .gitignore bower 12 gadi atpakaļ
.gitmodules e65704ab15 use public submodule url for reliable 12 gadi atpakaļ
LICENSE 332f2d486f license 12 gadi atpakaļ
Makefile ea9a3207cb submodules, gitignore, make 12 gadi atpakaļ
README.md 214a14cc10 navigator #98 11 gadi atpakaļ
changelog.md f3cfd6e13d 0.3.4 11 gadi atpakaļ
package.json c80acbb9f6 Update package.json to 0.3.4 11 gadi atpakaļ

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