webrtc 学习资源 http://www.cnblogs.com/lingyunhu/p/3578218.html
Realtime/Working WebRTC Experiments
- It is a repository of uniquely experimented WebRTC demos; written by Muaz Khan!
- No special requirement! Just WebRTC compatible web-browser (e.g. chrome/firefox/opera on desktop/android)
- These demos/experiments are entirely client-side; i.e. no server installation needed!
- You can use all these demos in PHP/Python/Ruby/ASP.NET/etc. everywhere!
How to use?
Each demo has a unique directory. Simply download that directory, upload in your webserver and use it; and it'll work!
You don't need to modify any single line to use it. No single installation or modification is needed :)
Libraries
| Library Name | Short Description | Doc | Demos |
|---|---|---|---|
RecordRTC.js |
Supports cross-browser audio/video recordings! | Doc | Demos |
Translator.js |
Voice & Text Translator | Doc | Demos |
RTCMultiConnection.js |
Single Library for Everything! Just imagine :) | Doc | Demos |
FileBufferReader.js |
File buffers reader & chunkifier | Doc | Demos |
getScreenId.js |
Single chrome extension for all domains! Again, imagine :) | Doc | Demos |
Conversation.js |
Enjoy Skype-like Conversations! Oops :) | Doc | Demos |
DataChannel.js |
Supports data-streaming among multiple peers | Doc | Demos |
getMediaElement.js |
A library for audio/video media elements' layout | Doc | Demos |
DetectRTC.js |
A library for detecting WebRTC features | Doc | Demos |
ConcatenateBlobs.js |
Concatenate Array of Blobs | Doc | Demos |
getStats.js |
Get peers statistics | Doc | None |
Other libraries:
- navigator.customGetUserMediaBar.js / Demo
- File.js / Demo
- Meeting.js / Demo
- RTCall.js / Demo
- SdpSerializer.js / Demo
Other Repositories
- WebRTC Scalable Broadcast
- Reliable Signaling
- RTCMultiConnection.js
- RecordRTC.js
- Collaborate Canvas Designer
- Translator.js
- FileBufferReader.js
- Chrome-Extensions
- Firefox-Extensions
- DetectRTC.js
- getStats.js
- Conversation.js
- Ffmpeg.js
- DataChannel.js
- MultiRTC Demos
- XHR-Signaling
- PluginRTC: IE/Safari Plugins compatible WebRTC-Experiments
- ASP.NET MVC based WebRTC 1:1 Demo
- WebSync Signaling
- SdpSerializer.js
Important Experiments
| Experiment Name | Short Description | Source | Demo |
|---|---|---|---|
Pre-recorded Media Streaming |
Stream video files in realtime; same like webcam streaming! | Source | Demo |
Part of Screen Sharing |
Share a region of the screen; not the entire screen! | Source | Demo |
Plugin-free Screen Sharing |
Share the entire screen | Source | Demo |
One-Way Broadcasting |
Same like radio stations; transmit audio/video/screen streams in one-way direction. Though, it is browser-to-browser streaming! | Source | Demo |
Useful Experiments
| Experiment Name | Previous Demos | New Demos |
|---|---|---|
| video-conferencing / multi-user (group) video sharing | Demo / Source | Demo / Source Code |
| file sharing / multi-user (group) files hangout | Demo / Source | Demo / Source Code |
| file sharing using SCTP data channels | Demo / -- | -- / Source Code |
| text chat / multi-user (group) text chat | Demo / Source | Demo / Source Code |
| MultiRTC | Demo / -- | -- / Source Code |
Google Chrome Extensions for WebRTC!
- desktopCapture API / Install App Store Extension
- tabCapture API / Install App Store Extension
- Desktop Sharing / Install App Store Extension
- File Sharing / Install App Store Extension
Firefox Extensions for WebRTC!
One-to-Many style of WebRTC Experiments
| Experiment Name | Previous Demos | New Demos |
|---|---|---|
| video-broadcasting | Demo / Source | Demo / Source Code |
| audio-broadcasting | Demo / Source | Demo / Source Code |
One-to-One Calls
| Experiment Name | Demo | Source Code |
|---|---|---|
| One-to-one WebRTC video chat using WebSocket | Demo | Source |
| One-to-one WebRTC video chat using socket.io | Demo | Source |
| WebRTC 1-1 Audio/Video/Screen Sharing | Source | Demo |
| WebRTC 1-1 Calls | Source | Demo |
Single-Page / One-Page / Client Side
| Experiment Name | Demo | Source Code |
|---|---|---|
| Switch streams from screen-sharing to audio+video. (Renegotiation) | Demo | Source |
| Share screen and audio/video from single peer connection! | Demo | Source |
| Text chat using RTCDataChannel APIs | Demo | Source |
| Simple video chat | Demo | Source |
| Sharing video - using socket.io for signaling | Demo | Source |
| Sharing video - using WebSockets for signaling | Demo | Source |
| Audio Only Streaming | Demo | Source |
| MediaStreamTrack.getSources | Demo | Source |
Experiments to share tab/screen/desktop
| Experiment Name | Previous Demos | New Demos |
|---|---|---|
| Plugin-free screen sharing / share the entire screen | Demo / Source | Demo / Source Code |
Desktop sharing / using desktopCapture APIs |
Demo / Source | -- |
Tab sharing / using tabCapture APIs |
Demo / Source | -- |
Experiments to share region/part of the screen
| Experiment Name | Demo | Source Code |
|---|---|---|
| Share part-of-screen RTCMultiConnection | Demo | Source |
| Share part-of-screen using RTCDataChannel APIs | Demo | Source |
| Share part-of-screen using Firebase | Demo | Source |
| A realtime chat using RTCDataChannel | Demo | Source |
| A realtime chat using Firebase | Demo | Source |
Demos using MediaStreamRecorder.js library
| Experiment Name | Demo | Source Code |
|---|---|---|
| Audio Recording | Demo | Source |
| Video Recording | Demo | Source |
| Gif Recording | Demo | Source |
Or RecordRTC entire Meeting using MediaStreamRecorder.js
Demos using DataChannel.js library
| Experiment Name | Demo | Source Code |
|---|---|---|
| DataChannel basic demo | Demo | Source |
| Auto Session Establishment | Demo | Source |
| Share part-of-screen using DataChannel.js | Demo | Source |
| Private Chat | Demo | ---- |
| Text Chat using Pusher and DataChannel.js | Demo | Source |
Experimental (Non-Functional)
| Experiment Name | Demo | Source Code |
|---|---|---|
| Attaching Remote Audio Streams | Demo | Source |
| mozCaptureStreamUntilEnded for pre-recorded media streaming | Demo | Source |
| Remote audio stream recording | Demo | Source |
Demos using RTCMultiConnection
| Experiment Name | Demo | Source Code |
|---|---|---|
| AppRTC like RTCMultiConnection demo! | Demo | Source |
| MultiRTC! RTCMultiConnection all-in-one demo! | Demo | Source |
| Collaborative Canvas Designer | Demo | Source |
| Conversation.js - Skype like library | Demo | Source |
| All-in-One test | Demo | Source |
| Multi-Broadcasters and Many Viewers | Demo | Source |
| Select Broadcaster at runtime | Demo | Source |
| OneWay Screen & Two-Way Audio | Demo | Source |
| Stream Mp3 Live | Demo | Source |
| Socket.io auto Open/Join rooms | Demo | Source |
| Screen Sharing & Cropping | Demo | Source |
| Share Part of Screen without cropping it | Demo | Source |
| getMediaDevices/enumerateDevices | Demo | Source |
| Renegotiation & Mute/UnMute/Stop | Demo | Source |
| Video-Conferencing | Demo | Source |
| Video Broadcasting | Demo | Source |
| Audio Conferencing | Demo | Source |
| Multi-streams attachment | Demo | Source |
| Admin/Guest audio/video calling | Demo | Source |
| Session Re-initiation Test | Demo | Source |
| Preview Screenshot of the room | Demo | Source |
| RecordRTC & RTCMultiConnection | Demo | Source |
| Explains how to customize ice servers; and resolutions | Demo | Source |
| Mute/Unmute and onmute/onunmute | Demo | Source |
| One-page demo: Explains how to skip external signalling gateways | Demo | Source |
| Password Protect Rooms: Explains how to authenticate users | Demo | Source |
| Session Management: Explains difference between "leave" and "close" methods | Demo | Source |
| Multi-Sessions Management | Demo | Source |
| Customizing Bandwidth | Demo | Source |
| Users ejection and presence detection | Demo | Source |
| Multi-Session Establishment | Demo | Source |
| Group File Sharing + Text Chat | Demo | Source |
| Audio Conferencing + File Sharing + Text Chat | Demo | Source |
| Join with/without camera | Demo | Source |
| Screen Sharing | Demo | Source |
| One-to-One file sharing | Demo | Source |
| Manual session establishment + extra data transmission | Demo | Source |
| Manual session establishment + extra data transmission + video conferencing | Demo | Source |
| takeSnapshot i.e. Take Snapshot of Local/Remote streams | Demo | Source |
| Audio/Video/Screen sharing and recording | Demo | Source |
| Broadcast Multiple-Cameras | Demo | Source |
| Remote Stream Forwarding | Demo | Source |
| WebRTC Scalable Broadcast | Socketio/Nodejs | Source |
Demos using Conversation.js
Documents for newcomers/newbies/beginners
| A few documents for newbies and beginners |
|---|
| How to use RTCPeerConnection.js? |
| RTCDataChannel for Beginners |
| How to use RTCDataChannel? - single code for both canary and nightly |
| WebRTC for Beginners: A getting stared guide! |
| WebRTC for Newbies |
| How to switch streams? |
| How to echo cancellation? / Noise management? |
| STUN or TURN? Which one to prefer; and why? |
| WebRTC RTP Usage |
| webrtcpedia! |
| Are you want to learn WebRTC? |
| WebRTC Tips & Tricks |
- http://muaz-khan.blogspot.com/search/label/WebRTC
- https://www.webrtc-experiment.com/#documentations
- https://www.facebook.com/WebRTC
- https://plus.google.com/+WebRTC-Experiment/posts
ffmpeg-asm.js && Ffmpeg Demos
| Demo Name | Live Demo | Source Code |
|---|---|---|
| Transcoding WAV into Ogg | Live Demo | Source Code |
| Transcoding WebM into mp4 | Live Demo | Source Code |
| Transcoding WebM into mp4; then merging WAV+mp4 into single mp4 | Live Demo | Source Code |
| Recording Audio+Canvas and merging in single mp4 | Live Demo | Source Code |
Custom Signaling
- Socket.io over Node.js
- WebSocket over Node.js
- WebSync / ASP.NET MVC
- XHR Signaling
- openSignalingChannel
How to record audio using RecordRTC?
<script src="//cdn.webrtc-experiment.com/RecordRTC.js"></script>
Documentation page: http://recordrtc.org/RecordRTC.html
var recordRTC = RecordRTC(mediaStream, {
type: 'video' // audio or video or gif or canvas
});
recordRTC.startRecording();
recordRTC.stopRecording(function(videoURL) {
video.src = videoURL;
var blob = recordRTC.blob;
var arrayBuffer = recordRTC.buffer;
recordRTC.getDataURL(callback_function);
});
- RecordRTC to Node.js
- RecordRTC to PHP
- RecordRTC to ASP.NET MVC
- RecordRTC & HTML-2-Canvas i.e. Canvas/HTML Recording!
- MRecordRTC i.e. Multi-RecordRTC!
- RecordRTC on Ruby!
- RecordRTC over Socket.io
- ffmpeg-asm.js and RecordRTC! Audio/Video Merging & Transcoding!
- Recording Audio+Video in single WebM on Firefox
- RecordRTC / PHP / FFmpeg
RTCMultiConnection.js
You can write entire skype-like web-app using RTCMultiConnection! It supports all complex renegotiation scenarios!
<button id="openRoom">Open Room</button>
<button id="joinRoom">Join Room</button><br /> <script src="//cdn.webrtc-experiment.com/RTCMultiConnection.js"> </script>
<script>
document.getElementById('openRoom').onclick = function() {
new RTCMultiConnection().open();
};
document.getElementById('joinRoom').onclick = function() {
new RTCMultiConnection().connect();
};
</script>
RTCMultiConnection Documentation
DataChannel.js / A library for RTCDataChannel APIs
<script src="//cdn.webrtc-experiment.com/DataChannel.js"> </script>
<script>
var datachannel = new DataChannel();
datachannel.onopen = function(remoteUserid) {};
datachannel.onmessage = function(message, remoteUserid) {}; // search for existing channels
datachannel.connect(); document.getElementById('new-channel').onclick = function() {
datachannel.open(); // setup new channel
};
</script>
Translator.js / Demo
Translator.js is a JavaScript library built top on Google Speech-Recognition & Translation API to transcript and translate voice and text. It supports many locales and brings globalization in WebRTC!
<script src="//cdn.webrtc-experiment.com/Translator.js"> </script>
var translator = new Translator();
translator.voiceToText(function (text) {
console.log('Your voice as text!', text);
}, 'your-language');
translator.translateLanguage(textToConvert, {
from: 'language-of-the-text',
to: 'convert-into',
callback: function (translatedText) {
console.log('translated text', translatedText);
}
});
translator.speakTextUsingRobot(textToPlay);
translator.speakTextUsingGoogleSpeaker({
textToSpeak: 'text-to-convert',
targetLanguage: 'your-language'
});
FileBufferReader.js / Demo
FileBufferReader is a JavaScript library reads file and returns chunkified array-buffers. The resulting buffers can be shared using WebRTC data channels or socket.io.
var fileBufferReader = new FileBufferReader();
fileBufferReader.readAsArrayBuffer(file, function(uuid) {
// var file = fileBufferReader.chunks[uuid];
// var listOfChunks = file.listOfChunks;
// get first chunk, and send using WebRTC data channels
// NEVER send chunks in loop; otherwise you'll face issues in slow networks
// remote peer should notify if it is ready for next chunk
fileBufferReader.getNextChunk(uuid, function(nextChunk, isLastChunk) {
if(isLastChunk) {
alert('File Successfully sent.');
}
// sending using WebRTC data channels
datachannel.send(nextChunk);
});
});
datachannel.onmessage = function(event) {
var chunk = event.data;
if (chunk instanceof ArrayBuffer || chunk instanceof DataView) {
// array buffers are passed using WebRTC data channels
// need to convert data back into JavaScript objects
fileBufferReader.convertToObject(chunk, function(object) {
datachannel.onmessage({
data: object
});
});
return;
}
// if you passed "extra-data", you can access it here:
// chunk.extra.senderUserName or whatever else
// if target peer requested next chunk
if(chunk.readyForNextChunk) {
fileBufferReader.getNextChunk(chunk.uuid, function(nextChunk, isLastChunk) {
if(isLastChunk) {
alert('File Successfully sent.');
}
// sending using WebRTC data channels
datachannel.send(nextChunk);
});
return;
}
// if chunk is received
fileBufferReader.addChunk(chunk, function(promptNextChunk) {
// request next chunk
datachannel.send(promptNextChunk);
});
};
getScreenId.js / Demo
Simply use getScreenId.js and enjoy screen capturing from any domain. You don't need to deploy chrome extension yourself. You can refer your users to install this chrome extension instead. Also,getScreenId.js auto-fallbacks to command-line based screen capturing if chrome extension isn't installed or disabled. getScreenId.js throws clear exceptions which is helpful for end-user experiences.
<script src="//cdn.WebRTC-Experiment.com/getScreenId.js"></script> <script>
getScreenId(function (error, sourceId, screen_constraints) {
navigator.getUserMedia = navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
navigator.getUserMedia(screen_constraints, function (stream) {
document.querySelector('video').src = URL.createObjectURL(stream);
}, function (error) {
console.error(error);
});
});
</script>
Signaling?
Browser Support
WebRTC Experiments works fine on following web-browsers:
| Browser | Support |
|---|---|
| Firefox | Stable / Aurora / Nightly |
| Google Chrome | Stable / Canary / Beta / Dev |
| Opera | Stable / NEXT |
| Android | Chrome / Firefox / Opera |
Credits
- Muaz Khan - https://github.com/muaz-khan
webrtc 学习资源 http://www.cnblogs.com/lingyunhu/p/3578218.html的更多相关文章
- webrtc 学习资源
http://www.cnblogs.com/lingyunhu/tag/webrtc%20android%20ios/
- WebRTC 学习资源 电子书 WebRTC权威指南 Learning WebRTC
webRTC源码下载地址:https://pan.baidu.com/s/18CjClvAuz3B9oF33ngbJIw 提取码:wl1e 1.<WebRTC权威指南>第三版 中文版 本书 ...
- webrtc 学习资源1
1,http://www.webrtc.org/ webrtc官网,神马编译,神马下载,这里的解决方案才是最权威的. --------------------------------- 2,http ...
- webrtc学习资源
http://www.imaotao.cn/project/webrtc-201604
- WebRTC学习与DEMO资源一览
一. WebRTC学习 1.1 WebRTC现状 本人最早接触WebRTC是在2011年底,那时Google已经在Android源码中加入了webrtc源码,放在/external/webrtc/ ...
- WebRTC学习
1. WebRTC学习 1.1 WebRTC现状 本人最早接触WebRTC是在2011年底,那时Google已经在Android源码中加入了webrtc源码,放在/external/web ...
- angularJS学习资源最全汇总
基础 官方: http://docs.angularjs.org angularjs官方网站已被墙,可看 http://www.ngnice.com/: 官方zip下载包 https://github ...
- 学习资源asp.net
http://www.runoob.com ajax 同一表单,多部分提交.增加,修改,删除 服务器端控件: http://technet.microsoft.com/zh-cn/library/cc ...
- Git 操作 学习资源 网址
用git 有一段时间了,有点自己的小心得.个人觉得相对SVN来讲他更灵活,更合理. 陆陆续续的收集了一些学习资源: 1.理解Xcode 中的Git 版本控制 http://www.open-open. ...
随机推荐
- 使用viewPage实现图片轮播
概述 图片循环播放这种效果,在许多的场合都能看到,只要一打开各大主流网站的首页几乎都有一个这样的组件,它可以很显目的提供给用户最近最火热的信息.因为它应用得如此之广泛,今天,我们就来写一下这个组件. ...
- 两点C#的propertyGrid的使用心得【转】
源文:http://www.cnblogs.com/bicker/p/3318934.html 最近接触C#的PropertyGrid比较多,得到了两个小心得记录一下. 第1点是关于控制Propert ...
- Lucene 源码分析之倒排索引(一)
倒排索引是 Lucene 的核心数据结构,该系列文章将从源码层面(源码版本:Lucene-7.3.0)分析.该系列文章将以如下的思路展开. 什么是倒排索引? 如何定位 Lucene 中的倒排索引? 倒 ...
- intellij idea 的常用有用快捷键
ctrl + R:替换(这一点和office 中的ctrl + H不一样) ctrl + alt + L:自动整理代码(不会整理注释文件) ctrl + alt:(自动导入包,不能批量导入,有人评论批 ...
- Spring核心(ioc控制反转)
IoC,Inversion Of Control 即控制反转,由容器来管理业务对象之间的依赖关系,而非传统方式中的由代码来管理. 其本质.即将控制权由应用程序代码转到了外部容器,控制权的转移就是 ...
- ORCAD元件属性白色区域和黄色区域的理解
白色部分为instance属性,黄色部分为occurence 属性 在平坦式电路中,黄色部分是默认不显示的. 在层次式电路中,黄色部分会显示. 如果这两个区域的Reference不同,以黄色 ...
- man gitworkflows
gitworkflows(7) Manual Page NAME gitworkflows - An overview of recommended workflows with Git SYNOPS ...
- unittest相关文档
文档链接: http://blog.csdn.net/wangst4321/article/details/8454118
- linux 块设备驱动(二)——块设备数据结构
本文来源于: 1. http://www.cnblogs.com/dyllove98/archive/2013/07/01/3165567.html 块设备相关的数据结构以及接口: 块设备接口则相对复 ...
- HTML marquee标签
marquee语法 <marquee></marquee> 实例一<marquee>Hello, World</marquee> marquee常 ...