文档章节

认识和入门 WebRTC

chenbilly
 chenbilly
发布于 2016/05/23 12:11
字数 901
阅读 634
收藏 22

WebRTC,名称源自网页即时通讯(英语:Web Real-Time Communication)的缩写,是一个支持网页浏览器进行实时语音对话或视频对话的API。它于2011年6月1日开源并在Google、Mozilla、Opera支持下被纳入万维网联盟的W3C推荐标准

一、引言 最近有在关注Google IO 2016的同学应该知道,google发布了新的一款视频聊天工具Duo(http://www.coolapk.com/apk/com.google.android.apps.tachyon),这款应用是基于 Google全新的QUIC和WebRTC协议开发的,也就是我们今天这篇文章需要介绍的主角WebRTC。

二、它是什么 正如导语所言WebRTC是一种视频通话的一种标准,目的是通过浏览器提供简单的JS就可以达到实时通讯的能力.除了Safari之外,主流的Chrome,Firefox,Opera已经在最新的浏览器中支持WebRTC很久了,Firefox更利用WebRTC制作了Hello应用,有兴趣的同学可以在Firefox浏览器的右上角找到它,并快速的发起一个视频会议。

三、过程描述 只需要做到以下的十步,你就可以完成一个简单的WebRTC视频应用了。

progress

  1. 从本地的设备中获取一个MediaStream 对象
  2. 从本地 MediaStream中获取一个URL blob
  3. 使用获得的URL blob在本地设备中做预览
  4. 创建一个RTCPeerConnectiond对象
  5. 将本地Stream添加到步骤4中创建的Connection对象中
  6. 发你的本地session 描述到远程服务器.
  7. 接受远程设备的远程session 描述
  8. 处理你接受到的远程session描述,并将远程stream添加到你的RTCPeerConnectiond。
  9. 通过远程的stream,获取它的URL blob。
  10. 使用获取到的URL blob去播放远程设备的音频和视频。

至此10步,我们就完成了一个简单的1:1视频的过程了.

四、主要的API描述

WebRTC原生APIs文件是基于WebRTC规格书[1]撰写而成,这些API可分成Network Stream API、 RTCPeerConnection、Peer-to-peer Data API三类。

###Network Stream API### MediaStream:MediaStream用来表示一个媒体数据流。 MediaStreamTrack在浏览器中表示一个媒体源。

###RTCPeerConnection### RTCPeerConnection:一个RTCPeerConnection对象允许用户在两个浏览器之间直接通讯。 RTCIceCandidate:表示一个ICE协议的候选者。 RTCIceServer:表示一个ICE Server。

###Peer-to-peer Data API### DataChannel:数据通道(DataChannel)接口表示一个在两个节点之间的双向的数据通道。

五、学习的资源

针对于WebRTC的爱好学习者,本文罗列了一些学习的资源(干货)供大家参考。

  1. WebRTC Home
  2. WebRTC Android
  3. WebRTC iOS
  4. WebRTC G
  5. Muaz Kha 大神
  6. Github list

参考示例:

  1. AppRTC Github
  2. AppRTC DEMO
  3. Hublin Github
  4. Hublin DEMO
  5. AppStore 搜WebRTC ---> 一堆应用基于WebRTC

第三方接入服务:

  1. pubnub
  2. tokbox
  3. oovoo
  4. sinch

书籍(PPT)下载:

  1. WebRTC Tutorial
  2. WebRTC G PPT
  3. Real-time-communication-with-webrtc-peer-to-peer-in-the-browser
  4. WebRTCIEEE

##版权申明

版权归原作者所有,这里仅做收集整理,欢迎自由转载-非商用-非衍生-保持署名和链接。

本文中内容将持续更新。

ps:本文作者系代码牛(面对面的技术分享平台)讲师keepcleargas,正在进行基于WebRTC的学习和开发,有兴趣的可关注 代码牛 公众号,获取最新的WebRTC项目的最新博客信息.

© 著作权归作者所有

共有 人打赏支持
chenbilly
粉丝 16
博文 9
码字总数 7714
作品 0
杭州
程序员
了不起的WebRTC:生态日趋完善,或将实时音视频技术白菜化

本文原文由声网WebRTC技术专家毛玉杰分享。 1、前言 有人说 2017 年是 WebRTC 的转折之年,2018 年将是 WebRTC 的爆发之年,这并非没有根据。就在去年(2017年),WebRTC 1.0 标准草案出炉(...

JackJiang2011
06/04
0
0
腾讯技术分享:微信小程序音视频与WebRTC互通的技术思路和实践

1、概述 本文来自腾讯视频云终端技术总监rexchang(常青)技术分享,内容分别介绍了微信小程序视音视频和WebRTC的技术特征、差异等,并针对两者的技术差异分享和总结了微信小程序视音视频和W...

JackJiang2011
09/29
0
0
学习多媒体开发的正确姿势?陈功:看书 啃代码 搞插件

陈功说,要想学好多媒体开发,首先需要兴趣,接下来还需要好的方法。LiveVideoStack邮件采访了声网Agora首席WebRTC架构师,畅聊了自己的成长经历,WebRTC的演进趋势等。陈功表示,WebRTC的未...

vn9plgzvnps1522s82g
04/13
0
0
黄开宁:搞多媒体开发要掌握好信号处理、统计和数理分析

尽管有WebRTC和FFmpeg这样的超级工具,但多媒体开发的核心难点的难度并没有因此降低,这需要开发者掌握牢固的基础知识。LiveVideoStack专访了即构科技音视频技术资深架构师黄开宁,他对学习多...

livevideostack
05/15
0
0
iOS下音视频通信的实现-基于WebRTC

前言: WebRTC,名称源自网页实时通信(Web Real-Time Communication)的缩写,简而言之它是一个支持网页浏览器进行实时语音对话或视频对话的技术。 它为我们提供了视频会议的核心技术,包括...

ljianbing
06/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周六乱弹 —— 到底谁是小公猫……

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @莱布妮子:分享Trivium的单曲《Throes Of Perdition》 《Throes Of Perdition》- Trivium 手机党少年们想听歌,请使劲儿戳(这里) @小鱼丁:...

小小编辑
58分钟前
137
3
基础选择器

注意:本教程参考自网上流传的李兴华老师的jquery开发框架视频,但是苦于没有相应的配套笔记,由我本人做了相应的整理. 本次学习的内容 学习jquery提供的各种选择器的使用,掌握了jquery选择...

江戸川
今天
1
0
Spring中static变量不能@value注入的原因

今天本想使用@Value的方式使类中的变量获得yml文件中的配置值,然而一直失败,获得的一直为null。 类似于这样写的。 public class RedisShardedPool { private static ShardedJedisPool pool...

钟然千落
今天
2
0
CentOS7防火墙firewalld操作

firewalld Linux上新用的防火墙软件,跟iptables差不多的工具。 firewall-cmd 是 firewalld 的字符界面管理工具,firewalld是CentOS7的一大特性,最大的好处有两个:支持动态更新,不用重启服...

dingdayu
今天
1
0
关于组件化的最初步

一个工程可能会有多个版本,有国际版、国内版、还有针对各种不同的渠道化的打包版本、这个属于我们日常经常见到的打包差异化版本需求。 而对于工程的开发,比如以前的公司,分成了有三大块业...

DannyCoder
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部