如果,需要同时录制麦克风声音以及桌面声音,请看最后
以下代码中有用到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约束条件是否有效暂时也不确定。没试过。*/
}
}