Skip to content

UUoocl/keyboard_and_mouse_visuals

Repository files navigation

keyboard and mouse visuals

Use javaScript to Visualize keyboard and mouse input in OBS.
Create graphics to highlight mouse position and Key presses.

keyAndMouse.mp4

If your learning to code to make art, use OBS to share your creative expressions through live streams, online meetings or recordings.

The examples in this repository feature the javaScript libraries P5.js and Cables.gl. Both are free and open source tools for making beautiful interactive content.

How it works

  1. OBS captures keyboard and mouse input that happens anywhere on your computer.
  2. Keyboard and Mouse events trigger an Advanced Scene Switcher macro that displays the event data in a Text Source.
  3. A Browser Source with javaScript listens for changes and renders the visualization

image

Required Software

OBS and the following plug-ins are required.

Note

macOS Installing plug-in note:

  1. After Downloading a plug-in, expand the .zip file and in the expanded folder click to open the installer for your Mac.
  2. A warning will appear that Apple could not verify the plug-in. Click the "Done" button

image

  1. Go to System Settings,
    1. choose Privacy & Security settings.
    2. scroll to the bottom of the settings page.
    3. click "Open Anyway"

image

Getting started

Download this repository

  1. After installing OBS and the requisite plug-ins, download this repository.

image

  1. Extract the .zip download

Turn on the OBS WebSocket Server

OBS includes a webSocket server. The webSocket server will allow the Browser Source to receive the Keyboard and Mouse event messages.

  1. Turn on the WebSocKet Server, from the file menu select "Tools --> WebSocket Server Settings" image

  2. check the "Enable WebSocket server" setting

image

  1. Click the "Show Connect Info Button" to get the WebSocket Server Password.
  2. Navigate to the folder where extracted the "keyboard and mouse visuals" are saved.
  3. Open the file /browser_Sources/obs_webSocket_details/websocketDetails.js

Tip

>Use a Text Editor, like VS Code, to open the file.

  1. Enter the WebSocket Server Password.
    • enter the password after "PW":"
  2. Save the change to "websocketDetails.js"

Import Scene Collection

Use the file "Key_and_Mouse_Visuals_Collection.json" to configure OBS .

  • In OBS, on the file menu click "Scene Collection --> Import"

image

  • navigate to the file "Key_and_Mouse_Visuals_Collection.json", in the downloaded folder.

  • Change to the imported Scene Collection. "Scene Collection --> Key_and_Mouse_Visuals_Collection"

  • OBS will ask where the local webpages are located.

image

  • click the "Search Directory..." button
  • navigate to where this repo is saved on your computer.

User Interface.

The Source Dock Plug-in is used to display the Keyboard and Mouse values. Mouse Follow and Zoom controls allow switching the scene view.
image

[!NOTE] Rearrange the docks however you'd like.

Create your own Visualization

The repo includes a starter template to 
 - replace mouse input with eventListeners
 - add OBS WebSocket connection.  

Examples

Attribution for the examples used in this repo

Key overlay

keyAndMouse00108162

Mouse overlay

Example of mouse visualizations created with javaScript libraries.

keyAndMouse00108000

Follow and Zoom to Mouse

The Follow and Zoom to Mouse Visualizations are created using javaScript to control the OBS Plug-ins Advanced Mask and Move Transition.

Follow Mouse

keyAndMouse00108392

Zoom and Follow Mouse

keyAndMouse00108707

Learn javaScript

Recommendations for learning javascript with a creative coding approach

About

Visualize keyboard and mouse input in OBS.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages