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.
- 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.
npm install max4node
The Max for Live device is located in max_device/max4node.amxd
.
Drop the device in a MIDI track (doesn't matter which one).
var Max4Node = require('max4node');
var max = new Max4Node();
max.bind();
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);
});
Arm the first track.
max.set({
path: 'live_set tracks 0',
property: 'arm',
value: true
});
Play a clip.
max.call({
path: 'live_set tracks 0 clip_slots 3 clip',
method: 'fire'
});
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);
});
Number of clips in the track.
max.count({
path: 'live_set tracks 0',
property: 'clip_slots'
})
.once('value', function(count) {
console.log(count + ' clips');
});
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 is done with fake sockets, so you don't need to open Ableton and Max.
npm test
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).
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.