Skip to content

Commit

Permalink
Merge pull request #403 from linxmix/spike/3-band-eq
Browse files Browse the repository at this point in the history
Spike/3 band eq
  • Loading branch information
wolfbiter authored Oct 22, 2016
2 parents 9f63296 + 7b8fe88 commit ce71ecb
Show file tree
Hide file tree
Showing 4 changed files with 157 additions and 15 deletions.
6 changes: 6 additions & 0 deletions app/components/mix-builder/precision-controls/transition.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,9 @@ import {

import {
CONTROL_TYPE_VOLUME,
CONTROL_TYPE_LOW_BAND,
CONTROL_TYPE_MID_BAND,
CONTROL_TYPE_HIGH_BAND,
CONTROL_TYPE_FILTER_HIGHPASS_CUTOFF,
CONTROL_TYPE_FILTER_LOWPASS_CUTOFF,
CONTROL_TYPE_DELAY_WET,
Expand All @@ -19,6 +22,9 @@ import {

const AUTOMATION_OPTIONS = {
[CONTROL_TYPE_VOLUME]: 'Volume',
[CONTROL_TYPE_LOW_BAND]: 'Low EQ',
[CONTROL_TYPE_MID_BAND]: 'Mid EQ',
[CONTROL_TYPE_HIGH_BAND]: 'High EQ',
[CONTROL_TYPE_FILTER_HIGHPASS_CUTOFF]: 'Highpass',
[CONTROL_TYPE_FILTER_LOWPASS_CUTOFF]: 'Lowpass',
[CONTROL_TYPE_DELAY_WET]: 'Delay Wet',
Expand Down
12 changes: 11 additions & 1 deletion app/mixins/playable-arrangement/automatable-clip/control.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ import RequireAttributes from 'linx/lib/require-attributes';
import { isValidNumber } from 'linx/lib/utils';

export const CONTROL_TYPE_VOLUME = 'gain';
export const CONTROL_TYPE_LOW_BAND = 'low-band';
export const CONTROL_TYPE_MID_BAND = 'mid-band';
export const CONTROL_TYPE_HIGH_BAND = 'high-band';
export const CONTROL_TYPE_BPM = 'bpm';
export const CONTROL_TYPE_PITCH = 'pitch';
export const CONTROL_TYPE_DELAY_WET = 'delay-wet';
Expand All @@ -21,7 +24,10 @@ export const CONTROL_TYPES = [
CONTROL_TYPE_DELAY_WET,
CONTROL_TYPE_DELAY_CUTOFF,
CONTROL_TYPE_FILTER_HIGHPASS_CUTOFF,
CONTROL_TYPE_FILTER_LOWPASS_CUTOFF
CONTROL_TYPE_FILTER_LOWPASS_CUTOFF,
CONTROL_TYPE_LOW_BAND,
CONTROL_TYPE_MID_BAND,
CONTROL_TYPE_HIGH_BAND
];

// Interface for Automatable Controls
Expand Down Expand Up @@ -49,6 +55,10 @@ export default function(audioParamPath) {
case CONTROL_TYPE_FILTER_HIGHPASS_CUTOFF:
case CONTROL_TYPE_FILTER_LOWPASS_CUTOFF:
return d3.scale.log().domain([20, 22050]).range([0, 1]);
case CONTROL_TYPE_LOW_BAND:
case CONTROL_TYPE_MID_BAND:
case CONTROL_TYPE_HIGH_BAND:
return d3.scale.linear().domain([-40, 40]).range([0, 1]);
default:
return d3.scale.identity();
}
Expand Down
82 changes: 68 additions & 14 deletions app/mixins/playable-arrangement/track-clip.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,9 @@ import {
import {
default as AutomatableClipControlMixin,
CONTROL_TYPE_VOLUME,
CONTROL_TYPE_LOW_BAND,
CONTROL_TYPE_MID_BAND,
CONTROL_TYPE_HIGH_BAND,
CONTROL_TYPE_PITCH,
CONTROL_TYPE_DELAY_WET,
CONTROL_TYPE_DELAY_CUTOFF,
Expand All @@ -32,42 +35,63 @@ import {

// TODO(CLEANUP): nest under track-clip/controls/gain?
const TrackVolumeControl = Ember.Object.extend(
AutomatableClipControlMixin('trackVolumeNode.gain'), {
new AutomatableClipControlMixin('trackVolumeNode.gain'), {

type: CONTROL_TYPE_VOLUME,
defaultValue: 1,
});

const TrackLowBandControl = Ember.Object.extend(
new AutomatableClipControlMixin('lowBandEqNode.filter.gain'), {

type: CONTROL_TYPE_LOW_BAND,
defaultValue: 6,
});

const TrackMidBandControl = Ember.Object.extend(
new AutomatableClipControlMixin('midBandEqNode.filter.gain'), {

type: CONTROL_TYPE_MID_BAND,
defaultValue: 6,
});

const TrackHighBandControl = Ember.Object.extend(
new AutomatableClipControlMixin('highBandEqNode.filter.gain'), {

type: CONTROL_TYPE_HIGH_BAND,
defaultValue: 6,
});

const TrackPitchControl = Ember.Object.extend(
AutomatableClipControlMixin('soundtouchNode.pitch'), {
new AutomatableClipControlMixin('soundtouchNode.pitch'), {

type: CONTROL_TYPE_PITCH,
defaultValue: 0,
});

const TrackDelayWetControl = Ember.Object.extend(
AutomatableClipControlMixin('tunaDelayNode.wet.gain'), {
new AutomatableClipControlMixin('tunaDelayNode.wet.gain'), {

type: CONTROL_TYPE_DELAY_WET,
defaultValue: 0,
});

const TrackDelayCutoffControl = Ember.Object.extend(
AutomatableClipControlMixin('tunaDelayNode.filter.frequency'), {
new AutomatableClipControlMixin('tunaDelayNode.filter.frequency'), {

type: CONTROL_TYPE_DELAY_CUTOFF,
defaultValue: 2000,
});

const TrackHighpassFilterCutoffControl = Ember.Object.extend(
AutomatableClipControlMixin('tunaHighpassFilterNode.filter.frequency'), {
new AutomatableClipControlMixin('tunaHighpassFilterNode.filter.frequency'), {

type: CONTROL_TYPE_FILTER_HIGHPASS_CUTOFF,
defaultValue: 20,
});

const TrackLowpassFilterCutoffControl = Ember.Object.extend(
AutomatableClipControlMixin('tunaLowpassFilterNode.filter.frequency'), {
new AutomatableClipControlMixin('tunaLowpassFilterNode.filter.frequency'), {

type: CONTROL_TYPE_FILTER_LOWPASS_CUTOFF,
defaultValue: 22050,
Expand All @@ -78,7 +102,7 @@ const TrackLowpassFilterCutoffControl = Ember.Object.extend(
export default Ember.Mixin.create(
AutomatableClipMixin,
PlayableClipMixin,
ReadinessMixin('isTrackClipReady'), {
new ReadinessMixin('isTrackClipReady'), {

// required params
track: null,
Expand All @@ -95,6 +119,9 @@ export default Ember.Mixin.create(
controls: Ember.computed(function() {
return [
TrackVolumeControl.create({ clip: this }),
TrackLowBandControl.create({ clip: this }),
TrackMidBandControl.create({ clip: this }),
TrackHighBandControl.create({ clip: this }),
TrackPitchControl.create({ clip: this }),
TrackDelayWetControl.create({ clip: this }),
TrackDelayCutoffControl.create({ clip: this }),
Expand Down Expand Up @@ -213,17 +240,32 @@ export default Ember.Mixin.create(

trackVolumeNode: computedObject(GainNode, {
'audioContext': 'audioContext',
'outputNode': 'tunaDelayNode.content',
'outputNode': 'lowBandEqNode.content',
}),

quarterNoteDelayTime: Ember.computed('syncBpm', function() {
// return bpmToSpb(this.get('syncBpm')) * 1000 * 3 / 4;
return bpmToSpb(this.get('syncBpm')) * 1000;
lowBandFilterType: 'lowshelf',
lowBandEqNode: computedObject(TunaFilterNode, {
'filterType': 'lowBandFilterType',
'frequency': 70,
'gain': 6,
'audioContext': 'audioContext',
'outputNode': 'midBandEqNode.content',
}),

tunaDelayNode: computedObject(TunaDelayNode, {
'bypass': 'delayBypass',
'delayTime': 'quarterNoteDelayTime',
midBandFilterType: 'peaking',
midBandEqNode: computedObject(TunaFilterNode, {
'filterType': 'midBandFilterType',
'frequency': 1000,
'gain': 6,
'audioContext': 'audioContext',
'outputNode': 'highBandEqNode.content',
}),

highBandFilterType: 'highshelf',
highBandEqNode: computedObject(TunaFilterNode, {
'filterType': 'highBandFilterType',
'frequency': 13000,
'gain': 6,
'audioContext': 'audioContext',
'outputNode': 'tunaHighpassFilterNode.content',
}),
Expand All @@ -241,6 +283,18 @@ export default Ember.Mixin.create(
'filterType': 'lowpassFilterType',
'frequency': 22050,
'audioContext': 'audioContext',
'outputNode': 'tunaDelayNode.content',
}),

quarterNoteDelayTime: Ember.computed('syncBpm', function() {
// return bpmToSpb(this.get('syncBpm')) * 1000 * 3 / 4;
return bpmToSpb(this.get('syncBpm')) * 1000;
}),

tunaDelayNode: computedObject(TunaDelayNode, {
'bypass': 'delayBypass',
'delayTime': 'quarterNoteDelayTime',
'audioContext': 'audioContext',
'outputNode': 'outputNode.content',
}),

Expand Down
72 changes: 72 additions & 0 deletions app/models/mix/transition.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@ import DependentRelationshipMixin from 'linx/mixins/models/dependent-relationshi

import {
CONTROL_TYPE_VOLUME,
CONTROL_TYPE_LOW_BAND,
CONTROL_TYPE_MID_BAND,
CONTROL_TYPE_HIGH_BAND,
CONTROL_TYPE_DELAY_WET,
CONTROL_TYPE_DELAY_CUTOFF,
CONTROL_TYPE_FILTER_HIGHPASS_CUTOFF,
Expand Down Expand Up @@ -69,6 +72,18 @@ export default DS.Model.extend(
controlType: CONTROL_TYPE_VOLUME,
transition: this,
});
const fromTrackLowBandClip = store.createRecord('mix/transition/from-track-automation-clip', {
controlType: CONTROL_TYPE_LOW_BAND,
transition: this,
});
const fromTrackMidBandClip = store.createRecord('mix/transition/from-track-automation-clip', {
controlType: CONTROL_TYPE_MID_BAND,
transition: this,
});
const fromTrackHighBandClip = store.createRecord('mix/transition/from-track-automation-clip', {
controlType: CONTROL_TYPE_HIGH_BAND,
transition: this,
});
const fromTrackDelayWetClip = store.createRecord('mix/transition/from-track-automation-clip', {
controlType: CONTROL_TYPE_DELAY_WET,
transition: this,
Expand All @@ -85,10 +100,23 @@ export default DS.Model.extend(
controlType: CONTROL_TYPE_FILTER_LOWPASS_CUTOFF,
transition: this,
});

const toTrackVolumeClip = store.createRecord('mix/transition/to-track-automation-clip', {
controlType: CONTROL_TYPE_VOLUME,
transition: this,
});
const toTrackLowBandClip = store.createRecord('mix/transition/to-track-automation-clip', {
controlType: CONTROL_TYPE_LOW_BAND,
transition: this,
});
const toTrackMidBandClip = store.createRecord('mix/transition/to-track-automation-clip', {
controlType: CONTROL_TYPE_MID_BAND,
transition: this,
});
const toTrackHighBandClip = store.createRecord('mix/transition/to-track-automation-clip', {
controlType: CONTROL_TYPE_HIGH_BAND,
transition: this,
});
const toTrackHighpassCutoffClip = store.createRecord('mix/transition/to-track-automation-clip', {
controlType: CONTROL_TYPE_FILTER_HIGHPASS_CUTOFF,
transition: this,
Expand All @@ -100,6 +128,9 @@ export default DS.Model.extend(

const fromTrackAutomationClips = [
fromTrackVolumeClip,
fromTrackLowBandClip,
fromTrackMidBandClip,
fromTrackHighBandClip,
fromTrackDelayWetClip,
fromTrackDelayCutoffClip,
fromTrackHighpassCutoffClip,
Expand All @@ -108,6 +139,9 @@ export default DS.Model.extend(

const toTrackAutomationClips = [
toTrackVolumeClip,
toTrackLowBandClip,
toTrackMidBandClip,
toTrackHighBandClip,
toTrackHighpassCutoffClip,
toTrackLowpassCutoffClip
];
Expand All @@ -125,6 +159,25 @@ export default DS.Model.extend(
direction: -1
}));

fromTrackLowBandClip.addControlPoints(generateControlPointParams({
startValue: 6,
endValue: 6,
n: volumeControlPointCount,
beatCount,
}));
fromTrackMidBandClip.addControlPoints(generateControlPointParams({
startValue: 6,
endValue: 6,
n: volumeControlPointCount,
beatCount,
}));
fromTrackHighBandClip.addControlPoints(generateControlPointParams({
startValue: 6,
endValue: 6,
n: volumeControlPointCount,
beatCount,
}));

fromTrackHighpassCutoffClip.addControlPoints(generateControlPointParams({
startValue: 20,
endValue: 20,
Expand Down Expand Up @@ -176,6 +229,25 @@ export default DS.Model.extend(
direction: 1
}));

toTrackLowBandClip.addControlPoints(generateControlPointParams({
startValue: 6,
endValue: 6,
n: volumeControlPointCount,
beatCount,
}));
toTrackMidBandClip.addControlPoints(generateControlPointParams({
startValue: 6,
endValue: 6,
n: volumeControlPointCount,
beatCount,
}));
toTrackHighBandClip.addControlPoints(generateControlPointParams({
startValue: 6,
endValue: 6,
n: volumeControlPointCount,
beatCount,
}));

toTrackHighpassCutoffClip.addControlPoints(generateControlPointParams({
startValue: 20,
endValue: 20,
Expand Down

0 comments on commit ce71ecb

Please sign in to comment.