Sem descrição

ericz 8f33da104c Build há 11 anos atrás
bin 3d4ec9bc66 fix supports há 12 anos atrás
deps e520030639 Update utf8 compatible by default binarypack há 11 anos atrás
dist 8f33da104c Build há 11 anos atrás
docs 98f43e5de1 Fixes #124 há 11 anos atrás
examples f1f4b23571 Update js-binarypack há 11 anos atrás
lib 0fabac677d Remove utf 8 references há 11 anos atrás
test 4d6f655823 Remove most old tests há 12 anos atrás
.gitignore 36291b993a #45 .gitignore bower há 12 anos atrás
.gitmodules e65704ab15 use public submodule url for reliable há 12 anos atrás
LICENSE 332f2d486f license há 12 anos atrás
Makefile ea9a3207cb submodules, gitignore, make há 12 anos atrás
README.md 214a14cc10 navigator #98 há 11 anos atrás
changelog.md a5db674ce7 Update changelog há 11 anos atrás
package.json 80937e2ce9 0.3.6 há 11 anos atrás

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