On Chrome 81, the deviceId field that the getDevices method returns is empty.
As of Chrome 81, device IDs are not exposed if permission to use devices has not been granted. This change is to protect user privacy.
For the Agora Web SDK, if you get device information before the method call of Stream.init succeeds, the returned deviceId may be empty.
You can create temporary streams for media capture to trigger the device permission request and get the device information.
Based on your requirements, create temporary streams for audio or video capture to trigger requests for microphone or camera permissions.
const tempAudioStream = AgoraRTC.createStream({ audio: true, video: false});
const tempVideoStream = AgoraRTC.createStream({ audio: false, video: true});
After the streams are initialized, call getDevices to get the complete device information.
deviceId and label fields in the returned device list.const audioPermissionOK = new Promise(resolve => {
tempAudioStream.init(() => resolve(null), (e) => resolve(e));
});
const videoPermissionOK = new Promise(resolve => {
tempVideoStream.init(() => resolve(null), (e) => resolve(e));
});
Promise.all([audioPermissionOK, videoPermissionOK]).then(res => {
if (res[0] !== null) {
console.warn("create audio temp stream failed!", res[0]);
}
if (res[1] !== null) {
console.warn("create video temp stream failed!", res[0]);
}
// After the capture, call getDevices to get device information
const devices = AgoraRTC.getDevices(info => {
tempAudioStream.close();
tempVideoStream.close();
console.log("get device info!", info);
});
});
Agora provides an online demo on obtaining device information.