Rust OSC client for Behringer X32 and X-Air digital mixers.
mixosc currently contains two pieces:
- A desktop GUI built with
icedthat discovers mixers on the local network and exposes a mixer-style control surface. - A Rust library for UDP/OSC discovery, connection probing, state loading, state updates, and meter parsing.
| Mixer | Channels | Buses | FX Returns | DCAs | Port |
|---|---|---|---|---|---|
| X32 / X32 Compact / X32 Producer / X32 Rack | 32 + 8 aux | 16 | 8 | 8 | 10023 |
| XR18 / XR16 / XR12 / X18 / X16 / X12 | 16 | 6 | 4 + 1 aux | 4 | 10024 |
The application discovers mixers automatically on the local network, connects to every mixer it finds, and opens a tab for each one. You can switch between mixers by clicking their tabs at the top of the window.
When only one mixer is discovered (or when a specific address is given), the tab bar still appears with a single tab.
The control surface loaded in each tab matches the detected model of that mixer.
CH 01-32AUX 01-08BUS 01-12FX 01-08MTX 01-06DCA 1-8Main LR
CH 01-16BUS 01-06FX 01-04+AUXDCA 1-4Main LR
For the strips that support them, the UI shows and updates in real time:
- Name and scribble-strip color
- Input gain or trim
- Sends
- Pan
- Fader level
- Input, bus, main/matrix meters, and RTA (Real-Time Analyzer)
- Mute
- Solo
The app subscribes to live OSC updates with /xremote and meter subscriptions, so local changes on the mixer are reflected back into the UI.
- Channels and aux inputs: gain/trim, sends to buses 1-16, pan, fader, mute, solo, color, name, meters
- FX returns: sends to buses 1-16, pan, fader, mute, solo, color, name
- Buses: sends to matrices 1-6, pan, fader, mute, solo, color, name, bus meters
- Matrices: fader, mute, color, name, matrix meter
- DCAs: fader, mute, color, name
- Main LR: fader, mute, color, stereo meter, RTA
- Channels: headamp gain, sends to buses 1-6, pan, fader, mute, solo, color, name, meters
- FX returns: sends to buses 1-6, pan, fader, mute, solo, color, name
- Buses: fader, mute, solo, color, name, bus meters
- DCAs: fader, mute, color, name
- Main LR: fader, mute, color, stereo meter, RTA
Implementation details from the current code:
- Gain uses headamp control where available and trim otherwise.
- On X32, channel
17-32use trim gain; earlier channels and supported aux inputs can use headamp gain. - On X-Air, all 16 channels have headamp gain.
- Gain is not exposed for buses, FX returns, matrices, or DCAs.
- Pan is not exposed for matrices or DCAs.
- DCA and matrix solo are not sent to the mixer.
- Master solo is only a local UI toggle right now; it is not sent to the mixer.
Automatic discovery on the local network (connects to all discovered mixers):
cargo runConnect to a specific mixer only:
cargo run -- 192.168.1.62You can also include a custom port:
cargo run -- 192.168.1.62:10023
cargo run -- 192.168.1.62:10024Or use the environment variable:
MIXOSC_MIXER_ADDR=192.168.1.62 cargo runDefault ports:
- X32:
10023 - X-Air (XR18, etc.):
10024
When no port is given, the app tries the default ports automatically.
The crate exports OSC helpers from src/common.rs, with model-specific implementations in src/x32.rs and src/xr18.rs:
- Discovery and connectivity:
DiscoveryProbe,ConnectionProbe,DiscoveredMixer,ProbeOutcome - Strip state loading and control:
FaderBankProbe,PanBankProbe,GainBankProbe,SendBankProbe,MuteBankProbe,SoloBankProbe,NameBankProbe,ColorBankProbe - Meter handling:
batchsubscribe_meter_request,renew_request,parse_input_meter_packet,parse_main_meter_packet,parse_rta_meter_packet - Console update parsing:
parse_console_update,ConsoleUpdate - Address parsing and constants:
parse_target,X32_DEFAULT_PORT,X32_BROADCAST_ADDR,XR18_DEFAULT_PORT,XR18_BROADCAST_ADDR,XREMOTE_REQUEST
This repository has a single binary entry point in src/main.rs and a reusable library in src/lib.rs.
