暫無描述

Eric Zhang fbbfb5fead Build 12 年之前
bin 3d4ec9bc66 fix supports 12 年之前
deps fbbfb5fead Build 12 年之前
dist fbbfb5fead Build 12 年之前
docs 292681d74f fork 12 年之前
examples e64bde1dce all use remote 0.3 12 年之前
lib 602db8de7c INTEROP 12 年之前
test 4d6f655823 Remove most old tests 12 年之前
.gitignore 36291b993a #45 .gitignore bower 12 年之前
.gitmodules e65704ab15 use public submodule url for reliable 12 年之前
LICENSE 332f2d486f license 12 年之前
Makefile ea9a3207cb submodules, gitignore, make 12 年之前
README.md 166eb8de1e Update README.md 12 年之前
changelog.md 9821d3e35a version/date 12 年之前
package.json 8433a2fd18 Version bump 12 年之前

README.md

PeerJS: peer-to-peer in the browser

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

##http://peerjs.com

Include the library

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

Peer

var peer = new Peer('thing1', {key: 'myapikey'}); // You can omit the ID if you want to get a random one from the server.

/** Data connections. */

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

/** Media calls. */

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

Connecting peer

var peer = new Peer('thing2', {key: 'myapikey'}); // You can omit the ID if you want to get a random one from the server.

/** Data connections. */

var connection = peer.connect('thing1');
connection.on('open', function() {
  connection.send('hi!'); // Send 'hi!' when the data connection opens.
});

/** Media calls. */

var getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
getUserMedia({video: true, audio: true}, function(stream) {
  var call = peer.call('thing1', stream);
  call.on('stream', function(stream) {
    // Show stream in some <video> element.
  });
}, function(err) {
  console.log(err);
});

Documentation

Browser compatibility status

PeerServer

Discuss PeerJS on our Google Group

Changelog