WebRTC中获取当前采集设备的deviceId

在做webRTC项目离不开切换摄像头,但是怎么拿到当前采集的设备id就成了问题,查阅资料后发现官方其实有提供相关方法,简单记录下;

通用玩法获取采集设备id
javascript 复制代码
// 请求访问用户媒体设备
navigator.mediaDevices.getUserMedia({ video: true, audio: true })
  .then((stream) => {
    // 获取视频轨道
    let videoTrack = stream.getVideoTracks()[0];
    if (videoTrack) {
      console.log('视频设备ID:', videoTrack.getSettings().deviceId);

      // 获取音频轨道
      let audioTrack = stream.getAudioTracks()[0];
      if (audioTrack) {
        console.log('麦克风设备ID:', audioTrack.getSettings().deviceId);
      }
    } else {
      console.log('未找到可用的视频设备');
    }
  })
  .catch((error) => {
    console.error('获取媒体流失败', error);
  });
相关推荐
WHOVENLY7 小时前
【javaScript】- 笔试题合集(长期更新,建议收藏,目前已更新至31题)
开发语言·前端·javascript
指尖跳动的光8 小时前
将多次提交合并成一次提交
前端·javascript
若梦plus8 小时前
JS之类型化数组
前端·javascript
若梦plus8 小时前
Canvas 深入解析:从基础到实战
前端·javascript
若梦plus8 小时前
Canvas渲染原理与浏览器图形管线
前端·javascript
C_心欲无痕8 小时前
vue3 - 依赖注入(provide/inject)组件跨层级通信的优雅方案
前端·javascript·vue.js
BD_Marathon9 小时前
Vue3_响应式数据的处理方式
前端·javascript·vue.js
嚣张丶小麦兜9 小时前
Vue常用工具库
前端·javascript·vue.js
Smile_2542204189 小时前
vlc的使用
网络·webrtc·实时音视频