Electron采集桌面共享和系統(tǒng)音頻(桌面捕獲)實(shí)例

Electron 開(kāi)發(fā)音視頻
在使用 Electron 開(kāi)發(fā)音視頻項(xiàng)目的時(shí)候,我們不可避免會(huì) 遇到桌面共享這種場(chǎng)景。
webRTC 提供了, getUserMedia 方法用于采集 用戶媒體數(shù)據(jù)。比如攝像頭,麥克風(fēng)。
設(shè)置主進(jìn)程信息
我們需要先在Electron 中,先創(chuàng)建窗體并載入入口 index 文件。
代碼如下:
const { app, BrowserWindow, desktopCapturer, ipcMain } = require('electron')
const path = require('path')
let win = null;
function createWindow () {
win = new BrowserWindow({
width: 800,
height: 600,
webPreferences: {
preload: path.join(__dirname, 'preload.js')
}
})
win.loadFile('index.html')
}
app.whenReady().then(() => {
createWindow()
app.on('activate', () => {
if (BrowserWindow.getAllWindows().length === 0) {
createWindow()
}
})
})
app.on('window-all-closed', () => {
if (process.platform !== 'darwin') {
app.quit()
}
})使用 desktopCapturer 模塊
desktopCapturer 模塊是Electron 提供的官方模塊用于捕獲系統(tǒng)桌面。 desktopCapture 支持捕獲,應(yīng)用窗口 和 桌面兩種媒體源。
但是,此模塊有使用限制,需要在主進(jìn)程進(jìn)行調(diào)用。 所以我們需要用到 Electron 中進(jìn)行間通信的方式。
所以我們需要通過(guò), IPC 通訊的形式,讓我們,在渲染進(jìn)程中進(jìn)行調(diào)用。
首先,我們?cè)?main.js 中,通過(guò) ipcMain 注冊(cè)一個(gè)方法,getSources
// .... other code
ipcMain.handle('getSources', async () => {
return await desktopCapturer.getSources({ types: ['window', 'screen'] })
})接著,我們?cè)阡秩具M(jìn)程中,通過(guò) ipcRenderer 去invoke 調(diào)用此方法便實(shí)現(xiàn)了,這個(gè)調(diào)用過(guò)程。
// .... other codes
const inputSources = await ipcRenderer.invoke('getSources')
// ... other codes獲得source 列表后, 我們?cè)阡秩具M(jìn)程中,通過(guò) HTML5 的 getUserMedia 進(jìn)行捕獲具體窗口或者桌面。
示例代碼:
// ...
// other Code
let constraints = {
audio: {
mandatory: {
chromeMediaSource: 'desktop'
}
},
video: {
mandatory: {
chromeMediaSource: 'desktop',
chromeMediaSourceId: sourceId
}
}
}
const stream = await navigator.mediaDevices
.getUserMedia(constraints);
handleStream(stream);
function handleStream (stream) {
const video = document.querySelector('video')
video.srcObject = stream
video.onloadedmetadata = (e) => video.play()
}
// ...
// other code至此我們就完成了, 桌面視頻數(shù)據(jù)采集了。
后續(xù)我們,可以對(duì)采集到的數(shù)據(jù)進(jìn)行 ,本地錄制或者 通過(guò)webrtc 推到遠(yuǎn)端等一系列操作。
總結(jié)
在electron 中實(shí)現(xiàn)桌面共享 和 chrome web 中差異還是蠻大的, 在chrome 中我們只需要調(diào)用 getDisplayMedia 方法就能喚起桌面選擇和畫(huà)面采集。
但在electron 中,我們需要使用到, 進(jìn)程間通信模塊 ipc 、 桌面采集模塊 desktopCapturer 、以及HTML5 的getUserMedia 方法才能完成整個(gè)桌面采集的過(guò)程。
關(guān)于完整代碼,我上傳到了github。
DEMO 代碼: https://github.com/shitouzxy/Electron-screenCapturerer-demo
以上就是Electron采集桌面共享和系統(tǒng)音頻(桌面捕獲)實(shí)例的詳細(xì)內(nèi)容,更多關(guān)于Electron桌面捕獲的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue使用distpicker插件實(shí)現(xiàn)省市級(jí)下拉框三級(jí)聯(lián)動(dòng)
這篇文章主要介紹了Vue使用distpicker插件實(shí)現(xiàn)省市級(jí)下拉框三級(jí)聯(lián)動(dòng),比如通過(guò)JSON文件生成對(duì)應(yīng)的區(qū)域下拉框,element-china-are插件,包括distpicker插件,通過(guò)代碼講解如何使用distpicker插件實(shí)現(xiàn)省市級(jí)三聯(lián)跳動(dòng),需要的朋友可以參考下2023-02-02
vue中調(diào)用百度地圖獲取經(jīng)緯度的實(shí)現(xiàn)
最近做個(gè)項(xiàng)目,需要實(shí)現(xiàn)獲取當(dāng)前位置的經(jīng)緯度,所以本文主要介紹了vue中調(diào)用百度地圖獲取經(jīng)緯度的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
vue將data恢復(fù)到初始狀態(tài) && 重新渲染組件實(shí)例
這篇文章主要介紹了vue將data恢復(fù)到初始狀態(tài) && 重新渲染組件實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
Vue使用枚舉類型實(shí)現(xiàn)HTML下拉框步驟詳解
本文分步驟給大家介紹了Vue使用枚舉類型實(shí)現(xiàn)HTML下拉框的相關(guān)知識(shí),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-02-02
Vue通過(guò)URL傳參如何控制全局console.log的開(kāi)關(guān)詳解
這篇文章主要給大家介紹了關(guān)于Vue根據(jù)URL傳參如何控制全局console.log開(kāi)關(guān)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-12-12

