A TouchDesigner component designed for the Intech Studio VSN1 that provides intuitive parameter control using endless relative MIDI encoders and mouse hover interactions. While optimized for VSN1, it can be made compatible with other endless relative MIDI controllers.
- Hover-based Control - Adjust any parameter by simply hovering your mouse over it
- VSN1 Integration - Full screen and LED feedback on VSN1 hardware
- Parameter Slots - Save parameters to buttons for instant recall across multiple banks
- ParGroup Support - Control entire parameter groups (RGB, XYZ) simultaneously
- Parameter Shortcuts - Quick button combos for reset, set default, clamp, and more
- Flexible Precision - Multiple step sizes with Fixed or Adaptive modes
- Network Zoom Navigation - Smooth zoom and pan in network editor when no parameter is active
- Smart Recovery - Automatic detection and fixing of invalid parameters when operators move
- Auto-Updates - Built-in updater with one-click updates from GitHub releases
-
Install Grid Package (one-time setup):
- Newer Grid Editor versions: Install
TouchDesigner Par Hover Controldirectly from Package Manager - Older versions: Clone repo, build, and add manually (see Getting Started)
- Search for, and import the
TouchDesigner Par Hover Controlconfiguration from Grid Editor to your VSN1 device
- Newer Grid Editor versions: Install
-
Download
ParHoverMIDI_VSN1.toxfrom the latest release -
Setup in TouchDesigner:
- Drag the
.toxinto your project at root/(recommended location) ⚠️ Important: Only one component instance per project, and only one project open at a time (communication/architecture limitation)- Keep Grid Editor open (component auto-launches it, needs exclusive access to port
9642) - Open TD's MIDI Device Mapper, set the VSN1 (Intech Grid MIDI Device) as Input and Output device, and note your Grid device's Device ID
- Set this
Device IDin component's VSN1/UI parameter page
- Drag the
-
Start Using:
- Hover over any parameter and twist your encoder to adjust it!
- Change step size with buttons under the LCD screen
- Save parameters to slots with long-press of primary buttons
- Switch between banks by long-pressing the step buttons
- 💡 Tip: Hover over any custom parameter while holding Alt (or Option on Mac) to see help text
- And much more! See User Guide for all features
Using other MIDI controllers? This component works with any endless/relative MIDI encoder. See Getting Started - Other Controllers for setup instructions.
📚 View Full Documentation Site (recommended)
Or browse the docs directly:
- Getting Started - Installation, MIDI setup, and first steps
- User Guide - Features, slots/banks, shortcuts, customization
- Quick Reference - Fast lookup tables for controls, parameters, and MIDI mappings
- Advanced - Recovery system, production setup, MIDI mapping, troubleshooting
Primary Target:
- Intech Studio VSN1 - Full support with screen updates and LED feedback
Alternative Hardware:
- Generic MIDI controllers with endless encoders in relative mode (no visual feedback)
- Turn off
VSN1 Supportparameter for non-VSN1 controllers
Requirements:
- TouchDesigner 2023.12120+ (or 2025.+ for controlling ParGroups)
- USB connection to MIDI controller
- For VSN1: Grid Editor open with exclusive access to port
9642
The component includes a built-in updater accessible from the About page:
- Open the component's About parameter page
- Check for and install new versions with one click
- View changelog before updating
Best Practice: Use the Externalize Component button in the About page before updating. This one-click setup preserves your slot data across all future updates. See Best Practices for Update Compatibility for details.
Contributions are welcome! Please:
- Test thoroughly with multiple MIDI controllers
- Maintain compatibility with existing configurations
- Document any new features or changes
See Development for project structure details.
Main Developer:
- Function Store - Project creator and lead developer
Special Thanks:
- Intech Studio - General support and hardware collaboration
- Greg Orca - Valuable feedback and ongoing support
- Dániel Pásztor - Queued screen updates and GitHub Actions implementation
- TheTouchLab - Network Editor mouse position tracking
- CarlosUnch - Testing and ideas
See LICENSE file for details.
Support: Contact @function.str on Discord or open an issue
