// 具体的 e 是什么,可以自己 log 一下,这里就不贴出来了
function gotDevices(devices) {
let cameras = []
for (let index = 0; index < devices.length; index++) {
const e = devices[index]
if (e.kind === ‘videoinput‘) {
cameras.push({
label: `摄像头[${index}]${e.label}`,
value: e.deviceId,
})
}
}
this.selCamera(this.cameras[0])
},
navigator.mediaDevices
.enumerateDevices()
.then(gotDevices)
.catch(err => {
this.$message.error(err.name + ‘: ‘ + err.message)
})
MediaDevices.getSupportedConstraints():getUserMedia 的参数是一个对象,理解成一个 config,可以使用此 API 获取支持的配置
//
let constraints = {
audio: true,
video: {
deviceId: { exact: e.deviceId },
width: { ideal: 1280 },
height: { ideal: 720 },
},
};
let promise = navigator.mediaDevices.getUserMedia(constraints);
promise
.then((MediaStream) => {
let video = this.$refs.video;
// 可以用于关闭流
this.mediaTrack = MediaStream.getTracks();
video.srcObject = MediaStream;
video.onloadedmetadata = function (e) {
video.play();
};
})
.catch((PermissionDeniedError) => {
if (
PermissionDeniedError.toString() ===
"NotFoundError: Requested device not found"
) {
this.$message.error("找不到摄像头");
} else {
this.$message.error(PermissionDeniedError.toString());
}
});
摆脱恼人的IE控件,mediaDevices Api 实现高拍仪抓拍
原文:https://www.cnblogs.com/marvelTitile/p/14719281.html