Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Feature Request] Isolate Input from Presentation Clickers (Support for Use While FreeShow is Out of Focus) #877

Open
jquyatt opened this issue Oct 9, 2024 · 9 comments
Labels
enhancement New feature or request

Comments

@jquyatt
Copy link

jquyatt commented Oct 9, 2024

Describe the feature
Allow FreeShow to detect and isolate input from a connected presentation clicker, enabling specific actions (e.g., advancing or reversing slides) to be triggered by the clicker even when FreeShow is minimized or not the active window. Other input devices (keyboards, mice, etc.) would not interfere with presentation actions.

Additional context
As a user running AV for live events, I often need to perform tasks across multiple applications while presenting. However, I still need to advance slides using a presenter clicker without having to constantly bring the FreeShow window into focus. This feature would provide me with more flexibility in multitasking, allowing smooth transitions in my workflow while ensuring clicker input still works as expected.

I have previously implemented a workaround for this issue with ProPresenter by using Karabiner Elements to isolate my presentation clicker's input and convert it to key presses F19 and F20, then using Hammerspoon to turn those key presses into API calls for next/previous slide. I feel that FreeShow could benefit from having a solution like this baked into the program itself, since it could isolate the key presses without having to translate them to other keys or use other programs to send API calls.

Proposed Solution

Since FreeShow is already built with Electron, this feature can be implemented using existing cross-platform Node.js modules to handle USB devices. Here’s a high-level approach:

  • Use Electron with Node-HID, Electron-HID, or a similar library to detect and handle USB devices like presentation clickers across Windows, macOS, and Linux.
  • Device Identification: Isolate the clicker by identifying it through its vendor and product ID.
  • Input Handling While Out of Focus: Allow the clicker’s input to trigger specific actions (e.g., advancing/reversing slides) even when FreeShow is minimized or out of focus.
  • Input Filtering: Ensure only the clicker is recognized for advancing slides while ignoring input from other devices (keyboards, mice, etc.).
@jquyatt jquyatt added the enhancement New feature or request label Oct 9, 2024
@vassbo
Copy link
Collaborator

vassbo commented Oct 10, 2024

Would be doable, do you in that case have examples of common vendor/product ids, and the input data they send with the click of different buttons?

@jquyatt
Copy link
Author

jquyatt commented Oct 10, 2024

In my case, I'm using the DSAN PerfectCue Micro (SCM Products), Vendor ID 1155 (0x0483), Product ID 8320 (0x2080). (I was able to simply pull that info from Karabiner-Elements.) It has a two button remote that sends right arrow and left arrow key presses.

I would think that you could use whichever module you choose to identify all the HIDs available and then possibly include a command training feature that listens for clicks from the device that you choose to assign the commands.

@mwb9aa
Copy link

mwb9aa commented Oct 23, 2024

@vassbo

In the program EasyWorship, you have to "register" remote devices. Maybe that feature would work here (even though the USB dongle for the clicker is local). You could have a settings option for people to "register" a clicker and then attach a listener to the specific USB device that captures input from that device. Some older clickers may also use the pg up or pg down keys, so you may want to have a spot for the end user to select which keys (arrows or pg up/down) to use. It could go in the Settings->Connections Tab.

@jquyatt
Copy link
Author

jquyatt commented Dec 5, 2024

Some older clickers may also use the pg up or pg down keys, so you may want to have a spot for the end user to select which keys (arrows or pg up/down) to use. It could go in the Settings->Connections Tab.

This reminds me a lot of a feature in ForScore sheet music software, where you can train different commands with MIDI signals. That could enable some useful customizations if you wanted to remap any of the clicker buttons for other features in FreeShow

@Auxority
Copy link

Auxority commented Dec 9, 2024

You could modify my Powerpoint AutoHotKey V2 script to target FreeShow instead: https://github.com/Auxority/powerpoint-focus-ahkv2

@leirbag28
Copy link

If I am not mistaken... Powerpoint on Windows works this way and WPS Office and SoftMaker Office on Linux as Well. At least once it is presenting. I do run MULTIPLE apps on different Workspaces while presenting and when I switch Workspaces to Present a PDF for example, then it focuses on that particular app on the screen.

@navhaxs
Copy link
Contributor

navhaxs commented Jan 15, 2025

This is an interesting but difficult problem to solve.
I have a proof of concept for a novel approach to solving this:

  1. A networked Raspberry Pi, with the USB clicker receiver attached. A "sender" app runs on this Pi and sends key presses over the network (via websockets)
  2. Then I have a "client" app on the actual desktop PC that will receive the key events from the network, and forward the next/previous key press to either:
  • ProPresenter, if projector window is open
  • PowerPoint, if presentation window is open
  • Else send key press to active window

Some code: https://github.com/navhaxs/ClickerFixer
It's just a proof of concept written in a totally different software stack, but throwing some ideas out there! I feel this pain at the AV desk all the time!

Using a HID library to intercept input events directly on the slides computer would be awesome, but I do think complex to implement (especially a cross-platform solution) but if anyone is experienced with how HID events work, I would love to see some movement on this :)

On Windows there used to be a library that could "intercept" keyboard input events easily but unfortunately required a paid license to work nicely https://github.com/oblitum/Interception

@mwb9aa
Copy link

mwb9aa commented Jan 15, 2025

@navhaxs, your method requires more equipment but is a good proof of concept. On Windows and Mac, this is already possible without extra hardware (see below). However, these solutions and your solution are more advanced, and many users will not want to tackle installing software, key bindings, etc.

  1. OS: Windows
    PowerPoint: can use FreeShow
    Item: network-connected device running ControlShow

  2. OS: Windows
    PowerPoint: Must Use
    Item: network-connected device running browser pointed to an instance of Bitfocus Companion running the powerpoint-remote-websocket module

  3. OS: Windows
    PowerPoint: Must Use
    Item: Clicker Must Use, clicker receiver plugged into the computer running @Auxority's AutoHotKey script (modified to target the keypress when PowerPoint is not active (lines 11-18)) (https://github.com/Auxority/powerpoint-focus-ahkv2).

  4. OS: Mac
    PowerPoint: Must Use
    Item: Clicker Must Use, clicker receiver plugged into the computer running Karabiner-Elements as mentioned by @jquyatt. I don't have a Mac and am not familiar with this program, but believe it works similarly to AutoHotKey.

  5. OS: Windows
    PowerPoint: Must Use
    Item: Clicker Must Use, clicker receiver connected to computer running modified version of @Auxority's script, has AutoHotInterception installed, and Bitfocus Companion which has the module powerpoint-remote-websocket module configured. This method would allow any networked computer and the clicker to be used to control PowerPoint.

@mwb9aa
Copy link

mwb9aa commented Jan 20, 2025

You might also follow this thread #1203 and see if any of those solutions work for you.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

6 participants