navigator.mediaDevices.getUserMedia录制桌面视频并保存

本文介绍了如何使用navigator.mediaDevices.getUserMedia结合electron.desktopCapturer录制桌面视频,并通过AudioContext API混音实现同时录制桌面声音和麦克风声音。在录制过程中,由于桌面音轨默认不包含麦克风声音,需要使用AudioContext将两者混合后再添加到视频流中。
摘要由CSDN通过智能技术生成

如果,需要同时录制麦克风声音以及桌面声音,请看最后

以下代码中有用到electron的desktopCapturer模块(用于PC应用开发),如果你并不需要,可以直接忽略,直接定义你要录制的视频源和音频源。重点如果要录制桌面,audio约束必须为 false,否则会报错,暂时不支持audio,如果你需要录制桌面的声音,则必须设置audio约束
audio: {
mandatory: {
chromeMediaSource: ‘desktop’
}
}

import {
   
  desktopCapturer
} from 'electron'

import fs from 'fs';


/**
 *自动录屏模块*录制桌面
 *
 * @class Recorder
 */
class Recorder {
   

  constructor(path) {
   
    this.mediaOutputPath = path;
  }


  /**
   *开始录制
   *
   * @memberof Recorder
   */
  startRecord = () => {
   

    desktopCapturer.getSources({
   
      types: ['screen']
    }, (error, sources) => {
   
      if (error) {
   
        throw error;
      }
      /* 要获取桌面音频必须设置audio约束如下 */
      navigator.mediaDevices.getUserMedia({
   
        audio:  {
   
          mandatory: {
   
            chromeMediaSource: 'desktop'
          }
        },
        video:   {
   
          mandatory: {
   
            chromeMediaSource: 'desktop',
            maxWidth: window.screen.width,
            maxHeight: window.screen.height
            /*cursor:"never" */
            /*取消录制鼠标,以免鼠标闪烁,这个目前标准定义了各浏览器还没实现,
            如果需要请使用webrtc-adapter,使用最新API,
            视频录制被单独分离成getDisplayMedia,
            但是cursor约束条件是否有效暂时也不确定。没试过。*/
          }
        }  
      
navigator.mediaDevices.getUserMedia()方法用于调用设备的摄像头和麦克风。然而,由于不同浏览器的兼容性问题,可能会导致该方法在某些浏览器中无法正常工作。以下是解决navigator.mediaDevices.getUserMedia兼容问题的方法: 1. 检查浏览器兼容性:在调用navigator.mediaDevices.getUserMedia()之前,可以使用以下代码检查浏览器是否支持该方法: ```javascript if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) { // 浏览器支持getUserMedia方法 } else { // 浏览器不支持getUserMedia方法 } ``` 2. 使用适配器库:为了解决不同浏览器之间的兼容性问题,可以使用适配器库,例如webrtc-adapter库。该库可以自动处理不同浏览器之间的差异,使得navigator.mediaDevices.getUserMedia()方法在所有浏览器中都能正常工作。你可以通过以下步骤使用webrtc-adapter库: a. 在HTML文件中引入webrtc-adapter库的脚本: ```html <script src="https://webrtc.github.io/adapter/adapter-latest.js"></script> ``` b. 在调用navigator.mediaDevices.getUserMedia()之前,不需要进行任何其他更改。 3. 检查设备权限:在某些情况下,navigator.mediaDevices.getUserMedia()方法可能无法正常工作是因为用户未授予访问摄像头和麦克风的权限。在调用该方法之前,可以使用以下代码检查用户是否已授予相应的权限: ```javascript navigator.permissions.query({ name: 'camera' }).then((permissionStatus) => { if (permissionStatus.state === 'granted') { // 用户已授予摄像头权限 } else { // 用户未授予摄像头权限 } }); ``` 如果用户未授予相应的权限,你可以提示用户授予权限或提供其他解决方案。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值