让这种代码工作很简单:
const videoTracks = this.localStream.getVideoTracks();
const audioTracks = this.localStream.getAudioTracks();
if (videoTracks.length > 0)
this.trace('Using video device: ' + videoTracks[0].label);
if (audioTracks.length > 0)
this.trace('Using audio device: ' + audioTracks[0].label);
在选择设备之前怎么样?
navigator.mediaDevices
.enumerateDevices()
.then(this.gotDevices.bind(this))
.catch(this.alertsService.add.bind(this.alertsService));
}
gotDevices(deviceInfos: MediaDeviceInfo[]) {
this.mediaDeviceInfos = deviceInfos;
this.mediaDeviceInfos.forEach(device => {
if (device.kind === 'audioinput')
this.mics.push(device);
else if (device.kind === 'videoinput')
this.cams.push(device);
else
console.warn(`Unexpected: ${JSON.stringify(device)}`);
});
}
this.mediaDeviceInfos.some(dev => dev.label)
是false
。所以我必须dev.deviceId
在我的输入中使用,这很难看:
我需要这里选择的特定设备,因为我使用它来支持多个摄像头和麦克风:
const constraints: MediaStreamConstraints = {
audio: { advanced: [{ deviceId: mic.deviceId, groupId: mic.groupId }] },
video: { advanced: [{ deviceId: cam.deviceId, groupId: cam.groupId }] }
};
如何获取相机和麦克风的标签,以便用户可以在主题中选择它们?