bitwig-gemini-mcp
Enables AI agents to control and monitor Bitwig Studio in real-time using natural language commands through MCP and OSC.
README
Bitwig Studio Gemini Agent Bridge (MCP)
This project provides a direct integration bridge between Gemini (via Model Context Protocol - MCP) and Bitwig Studio (via Open Sound Control - OSC). It allows an AI agent or the Gemini client to manage, control, and monitor your Bitwig Studio projects in real-time.
šļø Architecture
āāāāāāāāāāāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāāāāāāāāāā
ā ā JSON-RPC ā Node.js MCP Server ā OSC / UDP ā Bitwig JS Controller ā
ā Gemini Client / IDE ā āāāāāāāāāā> ā ā āāāāāāāāāā> ā ā
ā ā <āāāāāāāāāā ā (mcp-server.js) ā <āāāāāāāāāā ā (AntigravityController)ā
āāāāāāāāāāāāāāāāāāāāāāāāāāāā (Stdio) āāāāāāāāāāāāāāāāāāāāāāāāāāā (Ports 9000/9001) āāāāāāāāāāāāāāāāāāāāā
ā
ā Bitwig Controller API
ā¼
āāāāāāāāāāāāāāāāāāāāāāāāāāā
ā Bitwig Studio DAW ā
āāāāāāāāāāāāāāāāāāāāāāāāāāā
The bridge consists of two main components:
- Node.js MCP Server: Listens to Gemini commands over standard input/output, maps them to OSC messages, and sends them to Bitwig over UDP. It also starts a UDP receiver to get real-time status updates (playback, track volume, solo, mute) from Bitwig.
- Bitwig Controller Script: A JavaScript extension loaded directly inside Bitwig Studio that opens a UDP socket (port
9000) to receive OSC commands, executes actions natively using the Bitwig Controller API, and pushes state changes back to Node.js (port9001).
š Project Structure
/home/bedri/Bitwig Studio/Projects/BitWig/
āāā package.json # Project manifest (dependencies: node-osc)
āāā package-lock.json # Package lockfile
āāā mcp-server.js # Node.js MCP server (Stdio JSON-RPC bridge)
āāā start-mcp.sh # Executable launcher script
āāā README.md # This documentation
/home/bedri/Bitwig Studio/Controller Scripts/
āāā AntigravityController.control.js # Extension script loaded by Bitwig Studio
š Setup & Activation
The project has been automatically deployed, but here are the configuration references:
1. Gemini MCP Registration
The server is registered in your local Gemini Configuration file (~/.gemini/config/mcp_config.json) under the bitwig-agent key:
"bitwig-agent": {
"command": "node",
"args": [
"/home/bedri/Bitwig Studio/Projects/BitWig/mcp-server.js"
]
}
2. Enable in Bitwig Studio
- Launch Bitwig Studio.
- Open the dashboard (click the Bitwig logo at the top center) and navigate to Settings > Controllers.
- Click Add Controller.
- Set Vendor to
Antigravityand Model toGemini Controller Bridge. - The extension will automatically bind, starting the UDP servers on ports
9000(listening) and9001(sending).
š ļø Supported Tools & Commands
Gemini is equipped with the following tools through this MCP server:
| Tool Name | Parameters | Description |
|---|---|---|
get_state |
None | Retrieves transport play state, BPM, arranger loop status, and list of existing tracks. |
play |
None | Starts playback in Bitwig. |
stop |
None | Stops playback. |
record |
None | Toggles arranger recording. |
toggle_loop |
None | Toggles the arranger loop. |
set_tempo |
bpm (number) |
Adjusts the project tempo (e.g. 128.5). |
set_track_volume |
track_index (int), volume (float 0.0 - 1.0) |
Sets the volume level of a track. |
set_track_pan |
track_index (int), pan (float 0.0 - 1.0) |
Adjusts the panning of a track (0.5 is center). |
set_track_mute |
track_index (int), mute (bool) |
Mutes/unmutes a track. |
set_track_solo |
track_index (int), solo (bool) |
Solos/unsolos a track. |
set_track_arm |
track_index (int), arm (bool) |
Arms/disarms a track for recording. |
launch_scene |
scene_index (int) |
Launches a scene by index. |
undo |
None | Executes native Undo. |
redo |
None | Executes native Redo. |
š¬ Example Prompts
You can now command your DAW in natural language:
- "Start playback in Bitwig"
- "Set the project BPM to 124"
- "Mute track 2 and solo track 0"
- "Get the current tracks list and their volumes"
- "Turn arranger loop on"
- "Undo the last action"
š Troubleshooting
Flatpak Network Permissions
Because Bitwig is packaged as a Flatpak on your Linux system, it runs in a sandbox. If the OSC connection fails, grant Bitwig permission to share the host's loopback network interface by running the following command:
flatpak override --user --share=network com.bitwig.BitwigStudio
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.