/**
* 【MediaStream】
* MediaStream.addTrack() 向流媒体中加入不同的轨
* MediaStream.removeTrack*() 从流媒体中移除不需要的轨
* MediaStream.getVideoTracks() 拿到所有视频轨
* MediaStream.getAudioTracks() 拿到所有音频轨
* MediaStream.stop() 将流媒体关闭,调每一个媒体流中的stop
*
* 【MediaStream 事件】
* MediaStream.onaddtrack 添加轨时触发onaddtrack事件
* MediaStream.onremovetrack 移除轨时触发onremovetrack事件
* MediaStream.onended 当流结束时触发ended事件
*/
let videoPlayer = document.querySelector('video#player');
let gotMediaStream = (stream) => {
// stream 流里面包含 视频轨和音频轨
videoPlayer.srcObject = stream
// 拿到流后 获取到视频中所有的track 取其中第一个videotrack
let videoTrack = stream.getVideoTracks()[0]
console.log(videoTrack)
// 通过 videotrack 的getsettings 拿到constrants的对象
let videoConstraints = videoTrack.getSettings()
console.log(videoConstraints)
}
let handleError = (err) => {
console.log(`getUserMedia errpr:${err}`)
}
if(!navigator.mediaDevices || !navigator.mediaDevices.getUserMedia) {
console.log('getUserMedia is not supported!');
}else {
// 同时有视频数据和音频数据
let constrants = {
video: {
width: 640,
height: 480,
frameRate: 5,
facingMode: 'environment',
resizeMode: 'none'
},
audio: false
}
navigator.mediaDevices.getUserMedia(constrants)
.then(gotMediaStream)
.catch(handleError)
}
七、MediaStreamAPI及获取视频约束
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 原文链接http://www.cnblogs.com/kenshincui/p/4186022.html 音频在i...
- 视频采集模块在WebRTC数据流水线中负责从视频源采集视频数据,推送给流水线下一模块(本地回显模块或者编码模块)进...