Skip to content

Commit

Permalink
midi-components-0.0.js: Add JogWheel component
Browse files Browse the repository at this point in the history
Introduces a component intended to be mapped to the standard
jogwheel encoder + touch sensitive surface combo present on
most controllers nowadays.
  • Loading branch information
Swiftb0y committed Jun 9, 2022
1 parent 63938d0 commit 2742325
Showing 1 changed file with 62 additions and 0 deletions.
62 changes: 62 additions & 0 deletions res/controllers/midi-components-0.0.js
Original file line number Diff line number Diff line change
Expand Up @@ -725,6 +725,67 @@
}
});

var JogWheel = function(options) {
Component.call(this, options);

// TODO 2.4: replace lodash polyfills with Number.isInteger/isFinite

if (!_.isInteger(this.deck)) {
console.warn("missing scratch deck");
return;
}
if (!(this.deck > 0)) {
console.warn("invalid deck number: " + this.deck);
return;
}
if (!_.isInteger(this.wheelResolution)) {
console.warn("missing jogwheel resolution");
return;
}
if (!_.isFinite(this.alpha)) {
console.warn("missing alpha scratch parameter value");
return;
}
if (!_.isFinite(this.beta)) {
this.beta = this.alpha / 32;
}
if (!_.isFinite(this.rpm)) {
this.rpm = 33 + 1/3;
}
if (this.group === undefined) {
this.group = "[Channel" + this.deck + "]";
}
this.inKey = "jog";
};

JogWheel.prototype = new Component({
vinylMode: true,
isPress: Button.prototype.isPress,
inValueScale: function(value) {
// default implementation for converting signed ints
return value < 0x40 ? value : value - (this.max + 1);
},
inputWheel: function(_channel, _control, value, _status, _group) {
value = this.inValueScale(value);
if (engine.isScratching(this.deck)) {
engine.scratchTick(this.deck, value);
} else {
this.inSetValue(value);
}
},
inputTouch: function(channel, control, value, status, _group) {
if (this.isPress(channel, control, value, status) && this.vinylMode) {
engine.scratchEnable(this.deck,
this.wheelResolution,
this.rpm,
this.alpha,
this.beta);
} else {
engine.scratchDisable(this.deck);
}
},
});

var EffectUnit = function(unitNumbers, allowFocusWhenParametersHidden, colors) {
var eu = this;
this.focusChooseModeActive = false;
Expand Down Expand Up @@ -1177,6 +1238,7 @@
exports.Encoder = Encoder;
exports.ComponentContainer = ComponentContainer;
exports.Deck = Deck;
exports.JogWheel = JogWheel;
exports.EffectUnit = EffectUnit;
global.components = exports;
}(this));

0 comments on commit 2742325

Please sign in to comment.