All Projects → alpacaaa → max4node

alpacaaa / max4node

Licence: other
Control Ableton Live through Node.js. Yes, holy shit.

Programming Languages

coffeescript
4710 projects
javascript
184084 projects - #8 most used programming language

Ableton Live API for Node.js (through Max for Live)

This module exposes the Live Object Model so that it can be consumed directly from Node.js. It works by communicating with a Max for Live device (included in the repo) through udp sockets.

Requirements

  • Ableton Live 9
  • Max for Live (tested with version 7, might work with 6)

By default, the module binds on ports 9000 and 9001, so they need to be free.

Install

npm install max4node

Setup

The Max for Live device is located in max_device/max4node.amxd.
Drop the device in a MIDI track (doesn't matter which one).

Usage

var Max4Node = require('max4node');

var max = new Max4Node();
max.bind();
Get values

Get Master Track volume.

max.get({
  path: 'live_set master_track mixer_device volume',
  property: 'value'
})
.once('value', function(val) {
  console.log('Master track volume: ' + val);
});
Set values

Arm the first track.

max.set({
  path: 'live_set tracks 0',
  property: 'arm',
  value: true
});
Call functions

Play a clip.

max.call({
  path: 'live_set tracks 0 clip_slots 3 clip',
  method: 'fire'
});
Observe a value

Fire the callback with the updated position of the clip (if it's playing).

max.observe({
  path: 'live_set 0 clip_slots 3 clip',
  property: 'playing_position'
})
.on('value', function(val) {
  console.log('Playing position: ' + val);
});
Count

Number of clips in the track.

max.count({
  path: 'live_set tracks 0',
  property: 'clip_slots'
})
.once('value', function(count) {
  console.log(count + ' clips');
});
Promises

Promise based versions of get and count are available through max.promise().

max.promise().get({
  path: 'live_set master_track mixer_device volume',
  property: 'value'
})
.then(function(val) {
  console.log('Master track volume: ' + val);
});

max.promise().count({
  path: 'live_set tracks 0',
  property: 'clip_slots'
})
.then(function(count) {
  console.log(count + ' clips');
});

Testing

Testing is done with fake sockets, so you don't need to open Ableton and Max.

npm test

Big ups

I would have never been able to come up with the Max device without looking at the code of Fingz, an awesome project that you should definitely check out.
I learned a lot about Max from it, debugging in Max is as painful as listening to Justin Bieber, but it's the only way we have to access the Ableton API in a reliable manner (control surfaces programming is a joke, and not officially supported).

License

Copyright (c) 2015, Marco Sampellegrini [email protected]

Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies.

THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].