From f7885d90204eb8027c5c3ef47b64549f4c4cf340 Mon Sep 17 00:00:00 2001 From: Colin Troisemaine <{ID}+{username}@users.noreply.github.com> Date: Mon, 21 Oct 2024 18:37:29 +0200 Subject: [PATCH] Added basic screen capture --- electron_app/control_menu.html | 29 +++++++++++++++++++------- electron_app/main.js | 21 +++++++++++++++---- electron_app/preload.js | 10 --------- electron_app/renderer.js | 38 ++++++++++++++++++++++++++++++++++ 4 files changed, 76 insertions(+), 22 deletions(-) create mode 100644 electron_app/renderer.js diff --git a/electron_app/control_menu.html b/electron_app/control_menu.html index 27de13a..60c1c8f 100644 --- a/electron_app/control_menu.html +++ b/electron_app/control_menu.html @@ -1,15 +1,28 @@ - + - - Hello World! + + Live Desktop Translator + -

Hello World!

- We are using Node.js , - Chromium , - and Electron . +
+ + + +
+
+ + + +
+ + + + +
- + \ No newline at end of file diff --git a/electron_app/main.js b/electron_app/main.js index dfaab95..67b012a 100644 --- a/electron_app/main.js +++ b/electron_app/main.js @@ -1,16 +1,29 @@ -const { app, BrowserWindow } = require('electron') +const { app, BrowserWindow, desktopCapturer, session } = require('electron') const path = require('node:path') const createWindow = () => { const win = new BrowserWindow({ - width: 800, - height: 600, + width: 850, + height: 700, webPreferences: { - preload: path.join(__dirname, 'preload.js') + preload: path.join(__dirname, 'preload.js'), + nodeIntegration: true, + contextIsolation: false } }) + session.defaultSession.setDisplayMediaRequestHandler((request, callback) => { + desktopCapturer.getSources({ types: ['screen'] }).then((sources) => { + // Grant access to the first screen found. + callback({ video: sources[0] }) + }) + // If true, use the system picker if available. + // Note: this is currently experimental. If the system picker + // is available, it will be used and the media request handler + // will not be invoked. + }, { useSystemPicker: true }) + win.loadFile('electron_app/control_menu.html') } diff --git a/electron_app/preload.js b/electron_app/preload.js index 8439f65..e69de29 100644 --- a/electron_app/preload.js +++ b/electron_app/preload.js @@ -1,10 +0,0 @@ -window.addEventListener('DOMContentLoaded', () => { - const replaceText = (selector, text) => { - const element = document.getElementById(selector) - if (element) element.innerText = text - } - - for (const dependency of ['chrome', 'node', 'electron']) { - replaceText(`${dependency}-version`, process.versions[dependency]) - } -}) diff --git a/electron_app/renderer.js b/electron_app/renderer.js new file mode 100644 index 0000000..fcf1ddf --- /dev/null +++ b/electron_app/renderer.js @@ -0,0 +1,38 @@ +const startButton = document.getElementById('startButton') +const stopButton = document.getElementById('stopButton') +const videoSelectButton = document.getElementById('videoSelectButton') + +const video = document.querySelector('video') + +startButton.addEventListener('click', () => { + console.log("startButton") + navigator.mediaDevices.getDisplayMedia({ + audio: true, + video: { + width: 800, + height: 450, + frameRate: 30 + } + }).then(stream => { + video.srcObject = stream + video.onloadedmetadata = (e) => video.play() + }).catch(e => console.log(e)) +}) + +stopButton.addEventListener('click', () => { + console.log("stopButton") + video.pause() +}) + +// Get the available video sources +const { desktopCapturer } = require('electron') +videoSelectButton.addEventListener('click', () => { + console.log("videoSelectButton") + + const inputSources = desktopCapturer.getSources({ + types: ['window', 'screen'] + }); + + console.log(inputSources) + +})