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.
- OBS captures keyboard and mouse input that happens anywhere on your computer.
- Keyboard and Mouse events trigger an Advanced Scene Switcher macro that displays the event data in a Text Source.
- A Browser Source with javaScript listens for changes and renders the visualization
OBS and the following plug-ins are required.
- Advanced Scene Switcher
- Move Transition
- Source Dock
- Source Clone
- Advanced Masks
- Composite Blur
- Stroke Glow Shadow
Note
macOS Installing plug-in note:
- After Downloading a plug-in, expand the .zip file and in the expanded folder click to open the installer for your Mac.
- A warning will appear that Apple could not verify the plug-in. Click the "Done" button
- Go to System Settings,
- choose Privacy & Security settings.
- scroll to the bottom of the settings page.
- click "Open Anyway"
- After installing OBS and the requisite plug-ins, download this repository.
- Extract the .zip download
OBS includes a webSocket server. The webSocket server will allow the Browser Source to receive the Keyboard and Mouse event messages.
-
Turn on the WebSocKet Server, from the file menu select "Tools --> WebSocket Server Settings"
-
check the "Enable WebSocket server" setting
- Click the "Show Connect Info Button" to get the WebSocket Server Password.
- Navigate to the folder where extracted the "keyboard and mouse visuals" are saved.
- Open the file /browser_Sources/obs_webSocket_details/websocketDetails.js
Tip
>Use a Text Editor, like VS Code, to open the file.
- Enter the WebSocket Server Password.
- enter the password after "PW":"
- Save the change to "websocketDetails.js"
Use the file "Key_and_Mouse_Visuals_Collection.json" to configure OBS .
- In OBS, on the file menu click "Scene Collection --> Import"
-
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.
- click the "Search Directory..." button
- navigate to where this repo is saved on your computer.
The Source Dock Plug-in is used to display the Keyboard and Mouse values. Mouse Follow and Zoom controls allow switching the scene view.
[!NOTE] Rearrange the docks however you'd like.
The repo includes a starter template to
- replace mouse input with eventListeners
- add OBS WebSocket connection.
Attribution for the examples used in this repo
- Space Type Generator "Stripes" by Kiel Mutschelknaus
Example of mouse visualizations created with javaScript libraries.
The Follow and Zoom to Mouse Visualizations are created using javaScript to control the OBS Plug-ins Advanced Mask and Move Transition.
Follow Mouse
Zoom and Follow Mouse
Recommendations for learning javascript with a creative coding approach