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)
+
+})