بدون توضیح

Michelle Bu 141db74484 Fixes #232 by handling errors explicitly rather than trying to parse status codes and ready states. 11 سال پیش
bin 3d4ec9bc66 fix supports 12 سال پیش
deps e520030639 Update utf8 compatible by default binarypack 11 سال پیش
dist 141db74484 Fixes #232 by handling errors explicitly rather than trying to parse status codes and ready states. 11 سال پیش
docs 70b0861488 Update docs 11 سال پیش
examples 141db74484 Fixes #232 by handling errors explicitly rather than trying to parse status codes and ready states. 11 سال پیش
lib 141db74484 Fixes #232 by handling errors explicitly rather than trying to parse status codes and ready states. 11 سال پیش
test d8d82371a6 added adapter.js to the tests 11 سال پیش
.gitignore 36291b993a #45 .gitignore bower 12 سال پیش
.gitmodules e65704ab15 use public submodule url for reliable 12 سال پیش
LICENSE 582e4de3e4 update copyright year 11 سال پیش
Makefile ea9a3207cb submodules, gitignore, make 12 سال پیش
README.md 214a14cc10 navigator #98 11 سال پیش
changelog.md 56bbc2ed57 0.3.9 11 سال پیش
package.json 56bbc2ed57 0.3.9 11 سال پیش

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