aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--javascript/imageviewer.js35
-rw-r--r--javascript/imageviewerGamepad.js36
2 files changed, 40 insertions, 31 deletions
diff --git a/javascript/imageviewer.js b/javascript/imageviewer.js
index e5355d0b..fa7a67d5 100644
--- a/javascript/imageviewer.js
+++ b/javascript/imageviewer.js
@@ -220,37 +220,10 @@ document.addEventListener("DOMContentLoaded", function() {
modal.tabIndex = 0
modal.addEventListener('keydown', modalKeyHandler, true)
- let delay = 350//ms
- window.addEventListener('gamepadconnected', (e) => {
- console.log("Gamepad connected!")
- const gamepad = e.gamepad;
- setInterval(() => {
- const xValue = gamepad.axes[0].toFixed(2);
- if (xValue < -0.3) {
- modalPrevImage(e);
- } else if (xValue > 0.3) {
- modalNextImage(e);
- }
-
- }, delay);
- });
-
-
- let isScrolling = false;
- window.addEventListener('wheel', (e) => {
- if (isScrolling) return;
- isScrolling = true;
-
- if (e.deltaX <= -0.6) {
- modalPrevImage(e);
- } else if (e.deltaX >= 0.6) {
- modalNextImage(e);
- }
-
- setTimeout(() => {
- isScrolling = false;
- }, delay);
- });
+ // detect gamepads and enable related functionality
+ let gamepadScript = document.createElement('script');
+ gamepadScript.src = 'imageviewerGamepad.js';
+ document.body.appendChild(gamepadScript);
const modalControls = document.createElement('div')
modalControls.className = 'modalControls gradio-container';
diff --git a/javascript/imageviewerGamepad.js b/javascript/imageviewerGamepad.js
new file mode 100644
index 00000000..29bd7140
--- /dev/null
+++ b/javascript/imageviewerGamepad.js
@@ -0,0 +1,36 @@
+ let delay = 350//ms
+ window.addEventListener('gamepadconnected', (e) => {
+ console.log("Gamepad connected!")
+ const gamepad = e.gamepad;
+ setInterval(() => {
+ const xValue = gamepad.axes[0].toFixed(2);
+ if (xValue < -0.3) {
+ modalPrevImage(e);
+ } else if (xValue > 0.3) {
+ modalNextImage(e);
+ }
+
+ }, delay);
+ });
+
+
+ /*
+ Primarily for vr controller type pointer devices.
+ I use the wheel event because there's currently no way to do it properly with web xr.
+ */
+
+ let isScrolling = false;
+ window.addEventListener('wheel', (e) => {
+ if (isScrolling) return;
+ isScrolling = true;
+
+ if (e.deltaX <= -0.6) {
+ modalPrevImage(e);
+ } else if (e.deltaX >= 0.6) {
+ modalNextImage(e);
+ }
+
+ setTimeout(() => {
+ isScrolling = false;
+ }, delay);
+ }); \ No newline at end of file