webRTC脱坑笔记(二)— webRTC API之MediaStream(getUserMedia)
webRTC API
WebRTC API
包括媒体捕获、音频视频的编码和解码、传输层和会话管理。
getUserMedia()
:捕获音频和视频。MediaRecorder
:录制音频和视频。RTCPeerConnection
:在用户之间传输音频和视频。RTCDataChannel
:用户之间的流数据。
1.媒体捕获MediaStream(又名getUserMedia)
MediaStream
接口是一个媒体内容的流.,一个流包含几个轨道,比如视频和音频轨道。作用是从用户本地摄像机和麦克风访问媒体流。getUserMedia()
方法是访问本机输入设备的主要方式。
第一步是访问用户设备的摄像头和麦克风。我们检测可用设备的类型,获得用户访问这些设备的权限,并管理数据流。
注意:
- 实时音视频以流对象的形式表示
- 通过询问用户是否授权,有安全控制,只允许授予一次权限,此后不再要求访问
- 输入设备选择由
mediaStream
处理 - 每个
mediaStream
对象包括几个mediaStreamTRack
对象,代表来自不同设备的音视频 - 每个
mediaStreamTrack
对象可能包括几个信道(左声道和右声道) - 两种方法输出
mediaStream
对象。首先将音视频输出显示,设置srcObject
属性将MediaStream
附加到视频元素,然后将输出发送到RTCPeerConnection
对象,然后传送到远程对象。
(1)获取本地媒体流,并检测浏览器是否支持
navigator.mediaDevices.getUserMedia = navigator.mediaDevices.getUserMedia ||
navigator.mediaDevices.webkitGetUserMedia ||
navigator.mediaDevices.mozGetUserMedia ||
navigator.mediaDevices.msGetUserMedia; if (navigator.getUserMedia) {
// 支持
} else {
// 不支持
}
navigator.mediaDevices.getUserMedia({ video: true, audio: true }).then( ).catch( );
(2)接受的参数
getUserMedia
方法接受三个参数,第一个参数是一个对象,即约束条件,另外两个是成功回调函数和失败回调函数。
约束条件
约束条件里包括捕获对象,表示要获取哪些多媒体设备,你获取本地媒体流时是要求获取摄像头还是麦克风,也可以设置视频分辨率的值、宽高比、面向模式(前置还是后置摄像头)、帧速率、高度、宽度等。可以单独把约束条件提出来单独写。
navigator.mediaDevices.getUserMedia({
// 以下就是约束条件
video: true,
audio: true
})
.then(createConn )
.catch(
console.log(`getUserMedia() error: ${e.name}`);
); // 或者
let constraints = {
video: true,
audio: true,
...
}
navigator.mediaDevices.getUserMedia(constraints,onSuccess, onError)
除了指定捕获对象之外,还可以指定一些限制条件,比如视频的宽高等等。
let constraints = {
video: {
minWidth: 1280,
minHeight: 720
}
...
}
如果网页使用了getUserMedia
方法,浏览器就会询问用户,是否同意浏览器调用麦克风或摄像头。如果用户同意,就调用回调函数onSuccess
;如果用户拒绝,就调用回调函数onError
成功回调函数
获取多媒体设备成功时调用。onSuccess
回调函数的参数是一个数据流对象stream。stream.getAudioTracks
方法和stream.getVideoTracks
方法,分别返回一个数组,其成员是数据流包含的音轨和视轨(track
)。
使用的声音源和摄影头的数量,决定音轨和视轨的数量。比如,如果只使用一个摄像头获取视频,且不获取音频,那么视轨的数量为1,音轨的数量为0。每个音轨和视轨,有一个kind
属性,表示种类(video
或者audio
),和一个label
属性(比如FaceTime HD Camera (Built-in))
。
失败回调函数
获取多媒体失败时调用。Error
对象的code
属性有说明错误的类型:
- PERMISSION_DENIED:用户拒绝提供信息。
- NOT_SUPPORTED_ERROR:浏览器不支持硬件设备。
- MANDATORY_UNSATISFIED_ERROR:无法发现指定的硬件设备。
下面看一个完整例子:
let constraints = {video: true}; function onSuccess(stream) {
let video = document.querySelector("video");
// video.src = window.URL.createObjectURL(stream);这种写法已被移除
video.srcObject = stream;
} function onError(error) {
console.log("getUserMedia error: ", error);
} navigator.getUserMedia(constraints, onSuccess, onError);
注意,如果存在回声,应该在video
或者audio
节点处添加muted
,进行简单的回声消噪。
(3)屏幕捕获
可以看看这个例子
(4)方法
详情可见[mediaStream-MDN](
webRTC脱坑笔记(二)— webRTC API之MediaStream(getUserMedia)的更多相关文章
- webRTC脱坑笔记(一)— 初识webRTC
webRTC概述 WebRTC--- `Web browsers with Real-Time Communications (RTC)` WebRTC是一个开源项目,可以在`Web`和本机应用程序中 ...
- webRTC脱坑笔记(三)— webRTC API之RTCPeerConnection
RTCPeerConnection API是每个浏览器之间点对点连接的核心,RTCPeerConnection是WebRTC组件,用于处理对等体之间流数据的稳定和有效通信. RTCPeerConnec ...
- webRTC脱坑笔记(四)— windows下Nginx对Node服务的反向代理
Nginx反向代理 1.什么是反向代理 当我们有一个服务器集群,并且服务器集群中的每台服务器的内容一样的时候,同样我们要直接从个人电脑访问到服务器集群服务器的时候无法访问,必须通过第三方服务器才能访问 ...
- ZooKeeper学习笔记二:API基本使用
Grey ZooKeeper学习笔记二:API基本使用 准备工作 搭建一个zk集群,参考ZooKeeper学习笔记一:集群搭建. 确保项目可以访问集群的每个节点 新建一个基于jdk1.8的maven项 ...
- es6 入坑笔记(二)---函数扩展,箭头函数,扩展运算符...
函数扩展 1.函数可以有默认值 function demo( a = 10,b ){} 2.函数可以使用解构 function demo( { a = 0,b = 0 } = {} ){ } 3.函数 ...
- 一步步yum安装LNMP,脱坑笔记!!!
更改国内yum源: 1.备份yum源文件,位置在/etc/yum.repos.d/CentOS-Base.repo mv /etc/yum.repos.d/CentOS-Base.repo /etc/ ...
- pandas处理json脱坑(二)--jsonError: Expecting ',' delimiter: line 1 column 2674
Expecting ',' delimiter: line 1 column 2674 json_dict = json.loads(row[json_columns].replace("' ...
- WebRTC的学习(二)
英文原文的链接地址为:https://developer.mozilla.org/en-US/docs/Web/API/WebRTC_API/Overview WebRTC是由一些关联的API和协议一 ...
- WebRTC 入门教程(二)| WebRTC信令控制与STUN/TURN服务器搭建
WebRTC 入门教程(二)| WebRTC信令控制与STUN/TURN服务器搭建 四月 4, 2019 作者:李超,音视频技术专家.本文首发于 RTC 开发者社区,欢迎在社区留言与作者交流. htt ...
随机推荐
- 如何扩展 Create React App 的 Webpack 配置
如何扩展 Create React App 的 Webpack 配置 原文地址https://zhaozhiming.github.io/blog/2018/01/08/create-react-a ...
- 如何实现全屏遮罩(附Vue.extend和el-message源码学习)
[Vue]如何实现全屏遮罩(附Vue.extend和el-message源码学习) 在做个人项目的时候需要做一个类似于电子相册浏览的控件,实现过程中首先要实现全局遮罩,结合自己的思路并阅读了(饿了么) ...
- 如何在微信小程序中使用iconfont
开篇废话 开发过小程序的童鞋肯定都会遇到这样的问题,当我们在小程序中使用iconfont官方推荐的方法插入字体时,我们总会得到一个打印机(滑稽).那么如何在小程序中正确的使用iconfont呢? 一. ...
- scrapy之Request对象
我们在使用scrapy框架的时候,会经常疑惑,数据流是怎么样在各个组件中间传递的.最近经常用scrapy+selenium爬取淘宝,又因为今天周五心情好,本宝宝决定梳理一下这方面知识. scrapy中 ...
- (转)Kubernetes部署WordPress+MySQL
转:http://www.showerlee.com/archives/2336 这部分我们结合之前的k8s知识点给大家展示如何使用kubernetes部署wordpress+MySQL, 并利用NF ...
- Git009--分支管理&创建与合并分支
Git--分支管理&创建与合并分支 一.分支管理 本文来自于:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578 ...
- Pair Testing
All-Pairs Testing is a test design method to deal with the combinatorics problem of defining test ca ...
- stl(优先队列操作)
http://codeforces.com/gym/101911/problem/C Recently Monocarp has created his own mini-laboratory! Th ...
- Manacher(最长回文串)
http://acm.hdu.edu.cn/showproblem.php?pid=3068 最长回文 Problem Description 给出一个只由小写英文字符a,b,c...y,z组成的字符 ...
- Django学习记录--~Biubiubiu
Day One Django常用命令 1.创建Django网站框架 django-admin startproject mysite # mysite为定义的项目文件夹名称 2.超级用户创建 py m ...