borderlands supercollider code cover.psd

//Borderlands - Supercollider Patch
//by Nick Sibicky 2009-2010
//Un-comment the following text and execte to set buffer size BEFORE running patch
/*s.options.hardwareBufferSize = 64;
s.boot; // */
//Global Patch + settings
(
var latencycomp = 0.065, xmouse, ymouse, fshift1, fshift1mod, fshift1freq,
fftbuffersize, sr, fftresolution, mix = 0.9, wavbuffers = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], schedule,
ringmod1, cbuffer, susbuffer, graineng, graindelbuf, grainenvbuf, shiftfreq, pshift, pshiftgui, patdelaygui, patdelaywr,
patdelayonoff, patdelayread, delaybuf, reverbgen, reverbgui, routingmatrix, masterout, synthcall, synthnodes, fxstore,
clist, presetLink, presetOscLabel, fx25list, fx25store, matrixstore, matrixlist, presetdirectory, p2directory, globallagtime,
globalkrate, wavlist, wavstore, midic, learnslot, learnnum, automate, clearclock, globaldelaycomp;
//Global Settings
fftbuffersize = 4096;
sr = s.sampleRate;
fftresolution = sr/fftbuffersize;
sr.post;
" SR".postln;
fftbuffersize.post;
" FFT Size".postln;
schedule = Scheduler(SystemClock);
automate = 0; //to determine when automation should be read or be allowed to be manually adjusted
//Global Preset Manager
presetdirectory = "./mysounds/presets/"; //the location where presets will be stored
p2directory = "matrix25/";
fxstore = Array2D.new(14, 10);
clist = Array2D.new(14, 10);
matrixstore = Array2D.new(30, 15);
matrixlist = Array2D.new(30, 15);
fx25store = Array.fill(290, 0);
fx25list = Array.fill(290,0);
wavstore = Array.fill(50, 0);
wavlist = Array.fill(50,0);
globallagtime = 2;
globalkrate = 90;
globaldelaycomp = 0.06;
//GLOBAL DELAY COMPENSATION (for FX25)
for(0,29, {arg county;
//fill the matrix 2D array with "0"
for(0,14, {arg countx;
matrixstore[county, countx] = 0;
});
});
presetLink = ["presetBufferL", "presetBufferR", "presetFX25", "presetFX26", "presetFX27", "presetFX28",
"presetFX29",
"presetFX30", "presetFX31", "presetFX32", "presetmatrixtop", "presetmatrixbottom", "presetpantop",
"presetpanbottom"];
presetOscLabel = ["25matrix", "WavPlayer", "fx25", "fx26", "fx27", "fx28", "fx29", "fx30", "fx31", "fx32",
"matrixtop",
"matrixbottom", "pantop", "panbottom"];
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------clearclock = SynthDef("clear app clock", {arg foobar;
AppClock.clear;
Out.ar(0, SinOsc(440, 0, 0.5));
});
//--------------------------------------------------------------------------------------------------for(0,13, { arg count;
SynthDef(presetLink[count].asString, {arg temp, value1, value2, value3, value4, value5, value6, value7, value8,
value9, value10, value11, value12, value13, value14, value15, value16, krate=0, lagtime=1; var foo;
//foo = EnvGen.kr(Env([0,1],[1]), doneAction: 2);
SendReply.kr(Impulse.kr(krate), presetOscLabel[count].asSymbol, [Lag.kr(value1, lagtime),
Lag.kr(value2,lagtime),
Lag.kr(value3, lagtime), Lag.kr(value4,lagtime), Lag.kr(value5, lagtime),
Lag.kr(value6,lagtime),Lag.kr(value7, lagtime),
Lag.kr(value8,lagtime),Lag.kr(value9, lagtime), Lag.kr(value10,lagtime)]);
}).send(s);
});
SynthDef("matrixLink", {arg temp; var foo;
foo = EnvGen.kr(Env([0,1],[1]), doneAction: 2);
SendReply.kr(Impulse.kr(0.3), \matrixset);
SendReply.kr(Impulse.kr(0.3), \matrix25);
SendReply.kr(Impulse.kr(0.3), \wavplay);
}).send(s);
AppClock.sched(2, {
SynthDef("Preset Manager", {arg preset, out, inmidi, cnumber, cvalue; var temp, mywindow, testbutton, red, green,
blue,
testbutton2, savebutton, deletebutton, fxnum=0, newname, namingbox, presetlist, presetselect, phoffset,
pmypath,
pmyfiles,pfiles, pnames, pnumfiles, pcount, itemlist, rereadlist, resetbutton, blankbutton, directoryselect,
directorylist,
directorylabel, latchbutton, lagslider, lagnumbox, maxPresetsPerMenu;
mywindow = GUI.window.new("Preset Manager", Rect(260, 500, 255, 255)).front; //set back to "58" instead of
"258"
mywindow.view.background = Color(0,0,0);
red = 50; green = 135; blue = 185;
phoffset = 100;
maxPresetsPerMenu = 45;
pfiles = Array.newClear(maxPresetsPerMenu+1);
rereadlist = { //WILL NEED TO INCREASE LIST BELOW TO MATCH ITEMLIST ARRAY SIZE
pfiles = pmypath.files;
//presetlist = Object.readArchive(presetdirectory.asString++p2directory.asString++"Preset List");
//pfiles.writeArchive(presetdirectory.asString++p2directory.asString++"Preset List");
for(0, maxPresetsPerMenu, {arg count;
itemlist[count] = ((pfiles[count].asString).replace("PathName(", "").replace(presetdirectory.asString,
"").replace(")",""));
if(itemlist[count] == "nil", {itemlist[count] = ""}, {});
});
presetselect.items = [itemlist[0].asString, //the ".items" method does not support arrays so items are
individualized
itemlist[1].asString, itemlist[2].asString, itemlist[3].asString,
itemlist[4].asString, itemlist[5].asString, itemlist[6].asString, itemlist[7].asString, itemlist[8].asString,
itemlist[9].asString, itemlist[10].asString, itemlist[11].asString, itemlist[12].asString,
itemlist[13].asString,
itemlist[14].asString, itemlist[15].asString, itemlist[16].asString, itemlist[17].asString,
itemlist[18].asString,
itemlist[19].asString, itemlist[20].asString, itemlist[21].asString, itemlist[22].asString,
itemlist[23].asString,
itemlist[24].asString, itemlist[25].asString, itemlist[26].asString, itemlist[27].asString,
itemlist[28].asString,
itemlist[29].asString, itemlist[30].asString, itemlist[31].asString, itemlist[32].asString,
itemlist[33].asString,
itemlist[34].asString, itemlist[35].asString, itemlist[36].asString, itemlist[37].asString,
itemlist[38].asString,
itemlist[39].asString, itemlist[40].asString, itemlist[41].asString, itemlist[42].asString,
itemlist[43].asString,
itemlist[44].asString, itemlist[45].asString];
}; // end rereadlist function
StaticText(mywindow, Rect(50, 230, 200, 20)).background_(Color.new255(255,255,255));
StaticText(mywindow, Rect(51, 231, 48, 18)).background_(Color.new255(red-15, green-35, blue35)).string_(" Ramp");
lagnumbox= NumberBox(mywindow, Rect(211, 231, 39, 18)).background_(Color.new255(red-15,green-
35,blue-35));
lagslider = SCSlider(mywindow, Rect(100, 231, 110, 18)).background_(Color.new255(red-15,green35,blue-35))
.thumbSize_(10).step_(1/96);
lagslider.action = {arg test; var slidval;
fx25store[289] = lagslider.value; //STORES LAG VALUES TO LAST SLOT IN FX25STORE!
slidval = (lagslider.value)*(lagslider.value)*10;
lagnumbox.value = slidval;
globallagtime = slidval;
};
lagslider.valueAction = 0.5;
directorylabel = StaticText(mywindow, Rect(5,5, 100, 220)).background_(Color.new255(255,255,255));
directorylabel = StaticText(mywindow, Rect(6,6, 98, 18)).background_(Color.new255(red,green,blue)).string_
(" Directory Select");
//IF NEED TO ADD MORE DIRECTORIES TO MENU....THIS IS THE PLACE!
directorylist = ["Testing", "1st Movement", "2nd Movement", "3rd Movement", "4th Movement", "5th Movement",
"6th Movement", "7th Movement", "General Use"];
directoryselect = ListView(mywindow, Rect(6, 26, 98, 198));
directoryselect.items = [directorylist[0], directorylist[1], directorylist[2], directorylist[3], directorylist[4],
directorylist[5], directorylist[6], directorylist[7], directorylist[8]];
directoryselect.background = Gradient(Color.new255(red,green,blue), Color.new255(red-25,green-55,blue-55),
\v);
directoryselect.action = {arg menu;
presetdirectory = "./mysounds/"++directorylist[menu.value].asString++"/"; //the location where presets will
be stored
pmypath = PathName.new(presetdirectory.asString);// Read the directory
rereadlist.value;
}; //end directoryselect.action
latchbutton = Button(mywindow, Rect(5, 230, 40, 20)).states_([ // Latch Mode Button
["OFF", Color.black, Color.new255(red,green,blue)],
["ON", Color.black, Color.new255(255,0,0)]]);
latchbutton.action = {arg choice; var list, temptext;
automate = 1;
if(choice.value == 1, {
for(1,13, {arg count;
s.sendMsg(\n_set, 1990+count, \krate, globalkrate); });},
{for(1,13, {arg count;
s.sendMsg(\n_set, 1990+count, \krate, 0); });});
};
StaticText(mywindow, Rect(110,5, 140, 220)).background_(Color.new255(255,255,255)); //border for preset
select
savebutton = Button(mywindow, Rect(109+phoffset, 6, 40, 20)).states_([ // "SAVE" button for presets
["Save", Color.black, Color.new255(red,green,blue)]]);
savebutton.action = {arg choice; var list, temptext;
newname = namingbox.value;
fxstore.writeArchive(presetdirectory.asString++newname.asString);
fx25store.writeArchive(presetdirectory.asString++p2directory.asString++newname.asString++"25");
matrixstore.writeArchive(presetdirectory.asString++p2directory.asString++newname.asString++"matrix");
wavstore.writeArchive(presetdirectory.asString++p2directory.asString++newname.asString++"wav");
//update the directory
pfiles = pmypath.files;
//presetlist = Object.readArchive(presetdirectory.asString++p2directory.asString++"Preset List");
//pfiles.writeArchive(presetdirectory.asString++p2directory.asString++"Preset List");
while({pcount < maxPresetsPerMenu},
{
if(pfiles[pcount].asString == "nil", {pnumfiles = pcount; pcount=maxPresetsPerMenu;},
{pnames[pcount] = (pfiles[pcount].asString).replace("PathName(",
"").replace(presetdirectory.asString,
pcount.post; " ".post; pnames[pcount].asString.postln; });
pcount = pcount+1;
});
"").replace(")","");
for(0, maxPresetsPerMenu, {arg count;
if(count < pnumfiles, {itemlist[count] = pnames[count];},
{itemlist[count] = "";});
itemlist.writeArchive(presetdirectory.asString++p2directory.asString++"Preset List");
});
rereadlist.value;
}; //end "Save" button
deletebutton = Button(mywindow, Rect(109+phoffset, 26, 40, 20)).states_([ // "delete" button for presets
["Delete", Color.black, Color.new255(red,green,blue)]]);
deletebutton.action = {arg choice; var list, temptext;
newname = namingbox.value;
File.delete(presetdirectory.asString++newname.asString);
File.delete(presetdirectory.asString++p2directory.asString++newname.asString++"25");
File.delete(presetdirectory.asString++p2directory.asString++newname.asString++"matrix");
File.delete(presetdirectory.asString++p2directory.asString++newname.asString++"wav");
//update the directory
pfiles = pmypath.files;
while({pcount < maxPresetsPerMenu},
{
if(pfiles[pcount].asString == "nil", {pnumfiles = pcount; pcount=maxPresetsPerMenu;},
{pnames[pcount] =
(pfiles[pcount].asString).replace("PathName(./mysounds/presets/", "").replace(")","");
});
pcount = pcount+1;
});
for(0, maxPresetsPerMenu, {arg count;
if(count < pnumfiles, {itemlist[count] = pnames[count];},
{itemlist[count] = "";});
itemlist[count].postln;
});
rereadlist.value;
}; //end "delete" button action
//initialization
clist = Object.readArchive("./mysounds/presets/matrix25/reset"); // HARD CODED RESET LOCATION FOR
PRESET INIT
for(1,13, {arg count; var temp;
s.sendMsg(\s_new, presetLink[count].asSymbol, (1990+count),1,1, \value1,
clist[count,0],
\value2, clist[count,1], \value3, clist[count,2],\value4, clist[count,3],\value5,
clist[count,4],
\value6, clist[count,5], \value7, clist[count,6], \value8, clist[count,7],\value9,
clist[count,8],
\value10, clist[count,9]);
});
//NOTE!!! Currently the reset button is reading the reset, reset25, and resetmatrix files from a variable directory
resetbutton = Button(mywindow, Rect(109+phoffset, 46, 40, 20)).states_([ // "delete" button for presets
["Reset", Color.black, Color.new255(red,green,blue)]]);
resetbutton.action = {arg choice; var list, temptext;
fx25list = Object.readArchive("./mysounds/presets/matrix25/reset25");
lagslider.valueAction = 0;
AppClock.clear;
latchbutton.valueAction = 1;
AppClock.sched((0.1), {latchbutton.valueAction = 0});
clist = Object.readArchive("./mysounds/presets/matrix25/reset"); // HARD CODED RESET LOCATION
matrixlist = Object.readArchive("./mysounds/presets/matrix25/resetmatrix");
wavlist = Object.readArchive("./mysounds/presets/matrix25/resetwav");
for(1,13, {arg count; var temp;
s.sendMsg(\n_set, 1990+count, \value1, clist[count,0],
\value2, clist[count,1], \value3, clist[count,2],\value4, clist[count,3],\value5,
clist[count,4],
\value6, clist[count,5], \value7, clist[count,6], \value8, clist[count,7],\value9,
clist[count,8],
\value10, clist[count,9], \lagtime, ((fx25list[289]*fx25list[289])*10));
});
s.sendMsg(\s_new, "matrixLink", s.nextNodeID,1,1);
}; //end "reset" button action
blankbutton = Button(mywindow, Rect(109+phoffset, 66, 40, 158)).states_([ // dummy button
["", Color.black, Color.new255(red-25,green-55,blue-55)]]);
namingbox = TextField(mywindow, Rect(11+phoffset, 6, 96, 20));
namingbox.stringColor_(Color.new255(120,120,120));
namingbox.value = "new preset";
namingbox.action = {arg field;
newname = field.value;
newname.postln; "".postln;
};
presetselect = ListView(mywindow, Rect(111, 26, 98, 198));
pmypath = PathName.new("./mysounds/"++presetdirectory.asString);// Read the directory into buffers and count
# of files
pfiles = pmypath.files;
"".postln;
pnames = Array.newClear(maxPresetsPerMenu);
pcount=0;
while({pcount < maxPresetsPerMenu},
{
if(pfiles[pcount].asString == "nil", {pnumfiles = pcount; pcount=maxPresetsPerMenu;},
{pnames[pcount] = (pfiles[pcount].asString).replace("PathName(./mysounds/presets/",
"").replace(")","");
pnames[pcount].asString.postln; });
pcount = pcount+1;
});
itemlist = Array.newClear(maxPresetsPerMenu+1);
for(0, maxPresetsPerMenu, {arg count;
if(count < pnumfiles, {itemlist[count] = pnames[count];},
{itemlist[count] = "";});
});
rereadlist.value;
presetselect.background = Gradient(Color.new255(red,green,blue), Color.new255(red-25,green-55,blue-55), \v);
presetselect.action = {arg menu; var length;
newname = itemlist[menu.value].asString;
if(newname == "", {}, { //only execute rest of presetselect action if not blank!
AppClock.clear;
latchbutton.valueAction = 1;
fx25list =
Object.readArchive(presetdirectory.asString++p2directory.asString++(itemlist[menu.value].asString)++"25");
length = fx25list[289]*fx25list[289]*10;
AppClock.sched((1.2*length), {latchbutton.valueAction = 0});
namingbox.value = itemlist[menu.value].asString;
lagslider.valueAction = fx25list[289];
clist = Object.readArchive(presetdirectory.asString++(itemlist[menu.value].asString));
matrixlist =
Object.readArchive(presetdirectory.asString++p2directory.asString++(itemlist[menu.value].asString)++"matrix");
wavlist =
Object.readArchive(presetdirectory.asString++p2directory.asString++(itemlist[menu.value].asString)++"wav");
for(1,13, {arg count; var temp;
s.sendMsg(\n_set, 1990+count, \lagtime, length, \value1, clist[count,0],
\value2, clist[count,1], \value3, clist[count,2],\value4, clist[count,3],\value5,
clist[count,4],
\value6, clist[count,5], \value7, clist[count,6], \value8, clist[count,7],\value9,
clist[count,8],
\value10, clist[count,9]); //\lagtime, (fx25list[289]*fx25list[289])*10);
});
s.sendMsg(\s_new, "matrixLink", s.nextNodeID,1,1);
}); //end if(newname ..... to prevent "nil" from being executed
}; //end presetselect.action (list click function)
CmdPeriod.doOnce({mywindow.close});
}).send(s); //end "Preset Manager"
nil;
});//end scheduling initialization
//--------------------------------------------------------------------------------------------------------------------//--------------------------------------------------------------------------------------------------------------------//--------------------------------------------------------------------------------------------------------------------//MIDI assignment
AppClock.sched(2, { //for initialization
SynthDef("MIDI", {arg ccnum, fxslot = 0, fxnum = 0;
var mywindow, ccbox, currentslot, currentnum, temptext, red, green, blue, learnvheight, slotlist, parameterlist,
fx25list, fx26list, fx27list, fx28list, fx29list, fx30list, fx31list, fx32list, matrix1list, matrix2list, matrix1panlist,
matrix2panlist,
learnbutton, ccinput, setlist, linknumlist, linkslotlist, currentcc, cctracker;
red = 80;
green = 160;
blue = 65;
learnvheight = 30;
parameterlist = Array2D.new(12, 30);
slotlist = ["fx25", "fx26", "fx27", "fx28", "fx29", "fx30", "fx31", "fx32", "1-10", "11-18"];
//then list each fx slot's number of controls and then their lables
fx25list = [4, "Coarse Tempo", "Stereo Width", "Fine Tempo", "Beat Emphasis"];
fx26list = [10, "Transpose 1", "Gain 1", "Transpose 2", "Gain 2", "Transpose 3", "Gain 3", "Portamento Time",
"Grain Size", "Random Timing %", "Randomize Pitch"];
fx27list = [2, "Scratch Position", "Scratch Lag"];
fx28list = [6, "Grain Size %", "Grain Frequency", "Grain Density", "Max Grain Delay", "Grain Env Sustain %",
"Grain Symmetry"];
fx29list = [1, "Ring Mod Frequency"];
fx30list = [1, "Freq Shift Frequency"];
fx31list = [13, "Bin Shift %", "Shift Distance", "Update Frequency", "Pitch 1", "Gain 1", "Pitch 2", "Gain 2",
"Pitch 3", "Gain 3", "Pitch 4", "Gain 4", "Pitch 5", "Gain 5"];
fx32list = [4, "Reverb Time", "Damping", "Input Bandwidth", "Stereo Spread"];
matrix1list = [30, "Channel 1 Input Gain", "Channel 1 Panning", "Channel 1 Output Gain",
"Channel 2 Input Gain", "Channel 2 Panning", "Channel 2 Output Gain",
"Channel 3 Input Gain", "Channel 3 Panning", "Channel 3 Output Gain",
"Channel 4 Input Gain", "Channel 4 Panning", "Channel 4 Output Gain",
"Channel 5 Input Gain", "Channel 5 Panning", "Channel 5 Output Gain",
"Channel 6 Input Gain", "Channel 6 Panning", "Channel 6 Output Gain",
"Channel 7 Input Gain", "Channel 7 Panning", "Channel 7 Output Gain",
"Channel 8 Input Gain", "Channel 8 Panning", "Channel 8 Output Gain",
"Wav Player L Input Gain", "Wav Player L Panning", "Wav Player L Output Gain",
"Wav Player R Input Gain", "Wav Player R Panning", "Wav Player R Output Gain"];
matrix2list = [30, "FX Bus 25 Input Gain", "NA", "FX Bus 25 Output Gain",
"FX Bus 26 Input Gain", "FX Bus 26 Panning", "FX Bus 26 Output Gain",
"FX Bus 27 Input Gain", "FX Bus 27 Panning", "FX Bus 27 Output Gain",
"FX Bus 28 Input Gain", "NA", "FX Bus 25 Output Gain",
"FX Bus 29 Input Gain", "FX Bus 29 Panning", "FX Bus 29 Output Gain",
"FX Bus 30 Input Gain", "FX Bus 30 Panning", "FX Bus 30 Output Gain",
"FX Bus 31 Input Gain", "FX Bus 31 Panning", "FX Bus 31 Output Gain",
"FX Bus 32 Input Gain", "FX Bus 32 Panning", "FX Bus 32 Output Gain"];
for(0,9, {arg fxslotcount;
for(1,30, {arg numcount; var lookup;
lookup = case
{fxslotcount == 0} {fx25list[numcount]}
{fxslotcount == 1} {fx26list[numcount]}
{fxslotcount == 2} {fx27list[numcount]}
{fxslotcount == 3} {fx28list[numcount]}
{fxslotcount == 4} {fx29list[numcount]}
{fxslotcount == 5} {fx30list[numcount]}
{fxslotcount == 6} {fx31list[numcount]}
{fxslotcount == 7} {fx32list[numcount]}
{fxslotcount == 8} {matrix1list[numcount]}
{fxslotcount == 9} {matrix2list[numcount]};
parameterlist[fxslotcount, numcount] = lookup;
});
});
mywindow = GUI.window.new("MIDI Control", Rect(62, 500, 195, 255)).front;
mywindow.view.background = Color(0,0,0);
temptext = StaticText(mywindow, Rect(5, learnvheight, 185, 220)).background_(Color.new255(255,255,255));
linkslotlist = Array.newClear(128);
linknumlist = Array.newClear(128);
ccbox = Array.newClear(16);
currentslot = Array.newClear(16);
currentnum = Array.newClear(16);
cctracker = Array.newClear(128);
for(0,10, {arg rownum;
ccbox[rownum] = StaticText(mywindow, Rect(6, learnvheight+1+(rownum*20), 30, 18))
.background_(Color.new255(red-(rownum),green,blue)).string_("CC#");
currentslot[rownum] = StaticText(mywindow, Rect(38, learnvheight+1+(rownum*20), 50, 18))
.background_(Color.new255(red-(rownum),green,blue));
currentnum[rownum] = StaticText(mywindow, Rect(90, learnvheight+1+(rownum*20), 99, 18))
.background_(Color.new255(red-(rownum),green,blue));
}); //end for 0,12
learnbutton = Button(mywindow, Rect( 5, learnvheight-25, 185, 20))
.states_([["Click to learn last used CC", Color.black, Color.new255(red,green,blue)],
["Learning...", Color.black, Color.new255(255,0,0)]]);
learnbutton.action = {arg pressed;
//learnslot.post; " ".post; learnnum.postln;
//(fxslot.value).postln; (fxnum.value).postln;
if(pressed.value == 1, {
if(currentcc == nil, {}, { //makes sure that there is a previous cc registered
linkslotlist[currentcc] = learnslot;
linknumlist[currentcc] = learnnum;
ccbox[0].string_(currentcc.asString);
currentslot[0].string_(slotlist[learnslot-1].asString);
currentnum[0].string_(parameterlist[learnslot-1, learnnum+1].asString);
}); //end if nil
AppClock.sched(0.15, {learnbutton.valueAction = 0;});}, {/*linkslotlist.postln;*/});
//currentslot.string_(slotlist[([1,2,3].choose)].asString);
//currentnum.string_(parameterlist[([0,1,2,3,4].choose), ([0,1,2].choose)].asString);
};
setlist = [\value1, \value2, \value3, \value4, \value5, \value6, \value7, \value8, \value9, \value10];
//MIDI RESPONSE IS GENERATED HERE:
ccinput = CCResponder({ |src, chan, num, value|
if(linknumlist[num] == nil, {/*"no learnslot registered".postln;*/}, {
s.sendMsg(\n_set, 1991+((linkslotlist[num]).value), \lagtime, 0.05, \krate, globalkrate,
(setlist[(linknumlist[num])]).asSymbol, (value/127));
}); //end "if"
currentcc = num;
//(setlist[learnnum].asSymbol).postln; value.postln;
}, nil, nil, nil, nil);
/*currentnum.items_(["(Effect", "Transpose 1", "Gain 1", "Transpose 2", "Gain 2", "Transpose 3", "Gain 3",
"Portamento Time",
"Grain Size", "Random Timing %", "Randomize Pitch"]);*/
/*
OSCresponder(s.addr, "midilearn", {arg temp, value1, value2;
"it's midilearning!".postln;
{currentslot.string_((slotlist[(value2[3])]).asString);
currentnum.string_((parameterlist[(value2[4])]).asString);
temp.post; " ".post; value1.post; " ".post; value2.postln;
}.defer;
temp.post; " ".post; value1.post; " ".post; value2.postln;
}).add;
*/
CmdPeriod.doOnce({mywindow.close; ccinput.remove;});
}).send(s); //end "MIDI"
}); //end scheduling
//midic = Synth("MIDI"); // Don't need to call this? causing redudant node set messages? need to test more
//-----------------------------------------------------------------------------------------------------------------//-----------------------------------------------------------------------------------------------------------------//-----------------------------------------------------------------------------------------------------------------//Actual buffer/.wav player
SynthDef("Buffer Player",{arg buffertrigger=1;
Out.ar([23],
PlayBuf.ar(2, buffertrigger, BufRateScale.kr(buffertrigger), loop: 1)
)
}).send(s);
//-------------------------------------------------------------------------------------------------//Creates the Buffer Player Window
AppClock.sched(1, {
SynthDef("Buffer Window", {arg test=0; var mywindow, harmshiftslid, delaytimeslid, feedbackslid, rootpitchslid,
tempsynth;
var button1 = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], text1, mypath,
files,
names = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], exit=0, numfiles,
fxnum=1, displaynames =
[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], buttonheight, buttonwidth,
windowheight, windowwidth,
activebuttons, nodenum =
[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], wavresponder;
mypath = PathName.new("./mysounds/");
// Read the /mysounds directory into buffers and count # of files
files = mypath.files;
for(0, 45, //if need to load more than 20 files, make sure to make matrices larger!
{arg counter;
if(exit == 0, {
names[counter] = (files[counter].asString).replace("PathName(./", "").replace(")","");
displaynames[counter] = (names[counter].asString).replace(".wav","").replace("mysounds/","");
if(names[counter].asString == "nil", {numfiles = counter; exit=1; counter=24;},{
wavbuffers[counter] = Buffer.read(s, names[counter].asString, bufnum: counter);});
}, {}); //exit
});
/*numfiles.post;
" sound files loaded".postln;
" ".postln;*/
windowheight = 250;
windowwidth = 270;
mywindow = GUI.window.new("Stereo Wave Player", Rect(518, 500, windowwidth, windowheight)).front;
mywindow.view.background = Color(0,0,0);
buttonheight = 16;
buttonwidth = (0.5*windowwidth)-5;
if(numfiles < 16, {activebuttons = numfiles-1}, {activebuttons = 14});
for(0,activebuttons,
{arg buttonnum;
button1[buttonnum] = Button(mywindow, Rect(5,(buttonheight*buttonnum)+5,buttonwidth,buttonheight))
.states_([
[displaynames[buttonnum].asString, Color.black, Color.new255(190+(buttonnum),120(buttonnum*3),190+(buttonnum))],
["! "++displaynames[buttonnum].asString++" !", Color.black, Color.red]
]);
nodenum[buttonnum] = s.nextNodeID;
button1[buttonnum].action = {arg choice;
wavstore[buttonnum] = button1[buttonnum].value; //store status for presets
if (choice.value == 1, {s.sendMsg("/s_new", "Buffer Player", nodenum[buttonnum], 1,
1, "buffertrigger", buttonnum);},
{s.sendMsg("n_free", nodenum[buttonnum]);})
};
//Calls Buffer Player Synth
});
for(activebuttons+1,15,
{arg buttonnum;
if(buttonnum > 14, {}, {button1[buttonnum] = Button(mywindow,
Rect(5,(buttonheight*buttonnum)+5,buttonwidth,buttonheight))
.states_([
["", Color.black, Color.new255(190+(buttonnum),120-(buttonnum*3),190+(buttonnum))]]);
});
});
if(numfiles > 15, {
for(15,numfiles-1, //2nd column
{arg buttonnum;
button1[buttonnum] = Button(mywindow, Rect(5+buttonwidth,(buttonheight*(buttonnum15))+5,buttonwidth,buttonheight))
.states_([
[displaynames[buttonnum].asString, Color.black, Color.new255(190+(buttonnum-15),120((buttonnum-15)*3),
190+(buttonnum-15))],
["! "++displaynames[buttonnum].asString++" !", Color.black, Color.red]
]);
nodenum[buttonnum] = s.nextNodeID;
button1[buttonnum].action = {arg choice;
wavstore[buttonnum] = button1[buttonnum].value; //store status for presets
if (choice.value == 1, {s.sendMsg("/s_new", "Buffer Player", nodenum[buttonnum], 1,
1, "buffertrigger", buttonnum);},
{s.sendMsg("n_free", nodenum[buttonnum]);})
};
//Calls Buffer Player Synth
});
},{}); //end if numfiles > 14
if(numfiles-1 < 16, {activebuttons=15;}, {activebuttons = numfiles-1;});
for(activebuttons, 29, //2nd column
{arg buttonnum;
button1[buttonnum] = Button(mywindow, Rect(5+buttonwidth,(buttonheight*(buttonnum15))+5,buttonwidth,buttonheight))
.states_([
["", Color.black, Color.new255(190+(buttonnum-15),120-((buttonnum-15)*3),190+(buttonnum15))]]);});
wavresponder = OSCresponder(s.addr, "wavplay", {arg temp;
{
for(0,numfiles-1, {arg count; var track;
button1[count].valueAction = wavlist[count];
});
}.defer;
}).add;
/*OSCresponder(s.addr, "WavPlayer", {arg temp, value1, value2;
{for(0,numfiles-1, {arg count; var previousnum = 0;
if((value2[count+3] != previousnum),
{button1[count].valueAction = value2[count+3];
previousnum = value2[count+3];}, {});
});
}.defer;
}).add; */
CmdPeriod.doOnce({wavresponder.remove; mywindow.close});
}).send(s);
nil;
}); //end scheduler
//--------------------------------------------------------------------------------------------------
//-------------------------------------------------------------------------------------------------//Pattern Delay Processor (FX Slot 25)
delaybuf = Buffer.allocConsecutive(10, s,(sr*15), 1, bufnum: 41); //Use Buffer nums #41-50 for FX 25 delays
// read from buffer to playback
patdelayread = SynthDef("Pattern Delay Read", {arg deltime=0.5, beatnumber=0, beatvelocity=1, channel=0,
panning=0.5, spread=0, emphasis=0.5,
gain=1; var out, sign, delayed=0;
spread = (spread*(-2))+1; // convert to -1 to +1 scale
panning = ((panning*2)-1); //convert panning from 0-1 to -1 to +1 scale
panning = panning - (spread*panning);
panning = (panning+1)*0.5; //convert back to 0-1 scale
emphasis = Lag.kr(emphasis, 0.1);
delayed = DelTapRd.ar((41+channel), In.kr(channel+100), (deltime*beatnumber-globaldelaycomp), 2);
//Is delayed here
delayed = (delayed*(1-emphasis))+(delayed*beatvelocity*(emphasis));
Out.ar([35], delayed);
panning = Lag.kr(panning,0.1);
Out.ar(101, delayed*(1-panning));
Out.ar(102, delayed*(panning));
}).send(s);
// write to buffer
patdelaywr = SynthDef("Pattern Delay Write",{ arg out=0, synthfreq=100; var in, chain, kernel, deltime=0.5, channel=0,
delayed,
delcapture = [0,0,0,0,0,0,0,0,0,0,0,0,0];
in = InFeedback.ar(60); //takes from internal bus 60 for "FX slot 25"
for(0,8, {arg counter; var input=0;
if(counter == 8, {input = 10}, {input = counter});
delcapture[counter] = DelTapWr.ar((41+counter), InFeedback.ar(input+50));
Out.kr(100+counter, delcapture[counter]);
});
}).send(s);
//mute/unute for delayed output
patdelayonoff = SynthDef("Delay On Off", {arg fades = 0, gain=1; var tempL, tempR, masterpulse30;
tempL = Lag.kr(fades,0.1)*InFeedback.ar(101)*gain;
tempR = Lag.kr(fades,0.1)*InFeedback.ar(102)*gain;
masterpulse30 = Impulse.kr(30);
SendReply.kr(masterpulse30, "outlevelL11", Amplitude.ar(tempL,0,1)); //Sets Meter sig, attack time, release time
SendReply.kr(masterpulse30, "outlevelR11", Amplitude.ar(tempR,0,1)); //Sets Meter sig, attack time, release
time
Out.ar(33, tempL);
Out.ar(34, tempR);
}).send(s);
//----------------------(FX Slot 25)
//Creates Pattern Delay Gui
AppClock.sched(1, { //schedule this to initialize after other synthdefs
patdelaygui = SynthDef("Pattern Delay Gui", {arg test=0; var mywindow, dbutton, dbuttonID, red, green, blue, redy,
greeny, bluey,
redx, greenx, bluex, textdesc = [" Input 1", " Input 2", " Input 3", " Input 4", " Input 5", " Input 6", " Input 7", "
Input 8",
" FX Bus 25"], dbox = [0,0,0,0], dslid = [0,0,0,0], coffset, temptext, tempoc=114, tempof=0, newred, newgreen,
newblue, tracker,
delaycoarse, delayfine, delaytotal, beatkey = [1, 0.065, 0.25, 0.065], mod, fxnum=2, fx25responder1,
fx25responder2;
mywindow = GUI.window.new("Pattern Delay Module (25)", Rect(800, 75, 454, 165)).front;
mywindow.view.background = Color(0,0,0);
StaticText(mywindow, Rect(5,4, 55, 109)).background_(Color.new255(255,255,255));
dbutton = Array.newClear(320);
tracker = Array.fill(320, 0);
red = 120;
green = 140;
blue = 160;
redy = -3;
greeny = 0;
bluey = -2;
redx = 0;
greenx = 0;
bluex = 0;
for(0, 8, {arg ychannel;
for(0,31, {arg xpos; var index, highlight, rounded;
rounded = (xpos/4).round(1);
if(rounded == (xpos/4), {highlight = 30},{highlight = 0});
newred = red+(xpos*redx)+(ychannel*redy)+(highlight*1.5);
newgreen = green+(xpos*greenx)+(ychannel*greeny)+highlight;
newblue = blue+(xpos*bluex)+(ychannel*bluey)+(highlight);
index = (ychannel*32)+xpos;
dbutton[index] = Button(mywindow, Rect(65+(xpos*12),5+(ychannel*12),12,12))
.states_([
["", Color.black, Color.new255(newred,newgreen,newblue)],
["", Color.black, Color.red]
]);
dbutton[index].action = {arg choice;
fx25store[index] = dbutton[index].value; //store changes to matrix in fx25store
if (choice.value == 1, {
tracker[index] = 1;
mod = xpos%4;
s.sendMsg("/s_new", "Pattern Delay Read", (index+2000), 1, 1, \beatnumber,
(xpos/4), \channel, ychannel, \spread, dbox[1].value,
\beatvelocity, beatkey[mod], \emphasis, dbox[3].value, \deltime,
60/(dbox[0].value), \panning, rrand(0.0,1.0));},
{tracker[index] = 0;
s.sendMsg("n_free", (index+2000);)});
};
});//end of xpos loop
temptext = StaticText(mywindow, Rect(6, (12*ychannel)+5, 53,
11)).background_(Color.new255(newred+10, newgreen+10,
newblue+10)).string_(textdesc[ychannel].asString);
temptext.font = Font("Helvetica", 9);
}); //end of ychannel loop
StaticText(mywindow, Rect(5, 120, 173, 40)).background_(Color.new255(255,255,255));
StaticText(mywindow, Rect(178, 130, 45, 20)).background_(Color.new255(255,255,255));
StaticText(mywindow, Rect(5, 120, 173, 40)).background_(Color.new255(255,255,255));
red = newred;
green=newgreen;
blue=newblue;
//coarse tempo control
temptext = StaticText(mywindow, Rect(6, 121, 78, 18)).background_(Color.new255(red, green, blue)).string_(" BPM
Coarse");
dbox[0] = NumberBox(mywindow, Rect(179,131, 43, 18)).background_(Color.new255(red, green, blue));
dslid[0] = SCSlider(mywindow, Rect(87, 121, 89, 18)).background_(Color.new255(red, green,
blue)).thumbSize_(10).step_(0.01);
AppClock.sched(3, {
dslid[0].action = {var value;
//value.value.postln;
s.sendMsg(\n_set, 1990+2, \krate, 0);
learnslot = 1; learnnum = 0; //for MIDI learn
//try this: (for using gui while automation is "on")
s.sendMsg(\n_set, 1992, \value1, (dslid[0].value), \lagtime, 0);
fxstore[fxnum, 0] = dslid[0].value;
tempoc = ((dslid[0].value)*100)+64;
dbox[0].value = tempoc+tempof;
for(0, 320, {arg butnum;
if(tracker[butnum] == 1, {s.sendMsg(\n_set, butnum+2000, \deltime, 60/(dbox[0].value));},
{});
}); //end loop
};
}); //end appclock init
//Stereo Width Control
coffset = 226;
StaticText(mywindow, Rect(5+coffset, 120, 217, 40)).background_(Color.new255(255,255,255));
StaticText(mywindow, Rect(6+coffset, 121, 78, 18)).background_(Color.new255(red, green, blue)).string_("
Mono/Stereo");
dbox[1] = NumberBox(mywindow, Rect(190+coffset,121, 31, 18)).background_(Color.new255(red, green, blue));
dslid[1] = SCSlider(mywindow, Rect(87+coffset, 121, 100, 18)).background_(Color.new255(red, green,
blue)).thumbSize_(10);
AppClock.sched(3, {
dslid[1].action = {var value;
s.sendMsg(\n_set, 1990+2, \krate, 0);
learnslot = 1; learnnum = 1; //for MIDI learn
fxstore[fxnum, 1] = dslid[1].value;
value = (dslid[1].value);
dbox[1].value = value;
for(0, 320, {arg butnum;
if(tracker[butnum] == 1, {s.sendMsg(\n_set, butnum+2000, \spread, value);}, {});
}); //end loop
};
}); //end appclock init
//Beat Emphasis Control
StaticText(mywindow, Rect(6+coffset, 141, 78, 18)).background_(Color.new255(red, green, blue)).string_(" Beat
Emph.");
dbox[3] = NumberBox(mywindow, Rect(190+coffset,141, 31, 18)).background_(Color.new255(red, green, blue));
dslid[3] = SCSlider(mywindow, Rect(87+coffset, 141, 100, 18)).background_(Color.new255(red, green,
blue)).thumbSize_(10);
AppClock.sched(3, {
dslid[3].action = {var value;
s.sendMsg(\n_set, 1990+2, \krate, 0);
learnslot = 1; learnnum = 3; //for MIDI learn
fxstore[fxnum, 3] = dslid[3].value;
value = (dslid[3].value);
dbox[3].value = value;
for(0, 320, {arg butnum;
if(tracker[butnum] == 1, {s.sendMsg(\n_set, butnum+2000, \emphasis, value);}, {});
}); //end loop
};
}); //end appclock init
//Tempo Fine Control
coffset = 0;
temptext = StaticText(mywindow, Rect(6, 141, 78, 18)).background_(Color.new255(red, green, blue)).string_("
BPM Fine");
dslid[2] = SCSlider(mywindow, Rect(87, 141, 89, 18)).background_(Color.new255(red, green,
blue)).thumbSize_(10).step_(0.01);
AppClock.sched(3, {
dslid[2].action = {var value;
s.sendMsg(\n_set, 1990+2, \krate, 0);
learnslot = 1; learnnum = 2; //for MIDI learn
fxstore[fxnum, 2] = dslid[2].value;
tempof = (dslid[2].value);
dbox[0].value = tempof+tempoc;
for(0, 320, {arg butnum;
if(tracker[butnum] == 1, {s.sendMsg(\n_set, butnum+2000, \deltime, 60/(dbox[0].value));},
{});
}); //end loop
};
}); //end appclock init
for(0,3, {arg init;
dslid[init].valueAction = 0.5;
});
fx25responder1 = OSCresponder(s.addr, "matrix25", {arg temp;
//"its here!".postln;
{
//fx25list = Object.readArchive(presetdirectory.asString++"fx25 list");
for(0,287, {arg count; var track;
dbutton[count].valueAction = fx25list[count];
//dslid[count].valueAction = value2[count+3];
});
}.defer;
}).add;
fx25responder2 = OSCresponder(s.addr, "fx25", {arg temp, value1, value2;
//"its here!".postln;
{for(0,3, {arg count;
dslid[count].value = value2[count+3];
if(count == 2, {
fxstore[fxnum, 2] = dslid[2].value;
tempof = (dslid[2].value);
dbox[0].value = tempof+tempoc;
for(0, 320, {arg butnum;
if(tracker[butnum] == 1, {s.sendMsg(\n_set, butnum+2000, \deltime,
60/(dbox[0].value));}, {});
}); //end loop
}, {
if(count == 3, {
fxstore[fxnum, 3] = dslid[3].value;
dbox[3].value = dslid[3].value;
for(0, 320, {arg butnum;
if(tracker[butnum] == 1, {s.sendMsg(\n_set, butnum+2000, \emphasis,
dslid[3].value);}, {});
}); //end loop
}, {
if(count == 1, {
fxstore[fxnum, 1] = dslid[1].value;
dbox[1].value = dslid[1].value;
for(0, 320, {arg butnum;
if(tracker[butnum] == 1, {s.sendMsg(\n_set, butnum+2000,
\spread, dslid[1].value);}, {});
}); //end loop
}, {
s.sendMsg(\n_set, 1992, \value1, (dslid[0].value), \lagtime, 0);
fxstore[fxnum, 0] = dslid[0].value;
tempoc = ((dslid[0].value)*100)+64;
dbox[0].value = tempoc+tempof;
for(0, 320, {arg butnum;
if(tracker[butnum] == 1, {s.sendMsg(\n_set, butnum+2000,
\deltime, 60/(dbox[0].value));}, {});
}); //end loop
})})});
});
}.defer;
}).add;
CmdPeriod.doOnce({fx25responder1.remove; fx25responder2.remove; mywindow.close});
}).send(s);
nil;
}); //end scheduling
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//FX Slot 26 Pitch Shifter
pshift = SynthDef("Pitch Shift", {arg out=0, localbufsize = 1024, pshiftratio=1, pshiftratio2=1, pshiftratio3=1,
windowsize=0.1, prandomize=0,
timerandom=0.02, t1gain=1, t2gain=1, t3gain=1, lagtime=0.1; var tempout, tempout2, tempout3, in, supernice,
pout;
in = InFeedback.ar(61);
t1gain=t1gain.dbamp;
t2gain=t2gain.dbamp;
t3gain=t3gain.dbamp;
tempout = PitchShift.ar(in, windowsize, Lag.kr(pshiftratio.midiratio, lagtime), prandomize,
windowsize*timerandom);
tempout2 = PitchShift.ar(in, windowsize, Lag.kr(pshiftratio2.midiratio, lagtime), prandomize,
windowsize*timerandom);//creates 3rd harmony
tempout3 = PitchShift.ar(in, windowsize, Lag.kr(pshiftratio3.midiratio, lagtime), prandomize,
windowsize*timerandom);//creates 4th harmony
tempout = tempout*Lag.kr(t1gain, 0.1);
tempout2 = tempout2*Lag.kr(t2gain, 0.1);
tempout3 = tempout3*Lag.kr(t3gain, 0.1);
pout = tempout+tempout2+tempout3;
Out.ar([36], pout);
}).send(s);
//-------Pshift Gui
-----AppClock.sched(1, {
pshiftgui = SynthDef("Pitch Shifter", {arg out=0; var tempout, mywindow, pbox = [0,0,0,0,0,0,0,0,0,0,0,0,0,0], pslid =
[0,0,0,0,0,0,0,0,0,0,0,0,0],
basered, basegreen, baseblue, border, textdesc = Array.new(13), target = Array.new(13), slidval =
[0,0,0,0,0,0,0,0,0,0,0,0,0,0],
scalefac = [0, 24, 2, 24, 2, 24, 2, 1, 0.3, 0.99, 0.1, 1], scalecons = [99, -12, 0, -12, 0, -12, 0,0,0,0.1,0,0,0],
initialize = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,], horizred, horizgreen, horizblue, hilite, fxnum=3,
presponder;
mywindow = GUI.window.new("Pitch Shifter/Harmonizer (26)", Rect(1001, 535, 260, 210)).front;
mywindow.view.background = Color.new255(0,0,0);
basered=157;
basegreen=122;
baseblue=200;
horizred = -3; //horizred...etc is for a smilght darkening from left to right
horizgreen = -3;
horizblue = -3;
hilite = 10; //hilite is for a vertical highlight on the labels and number box (does not apply to slider)
textdesc = [" ", " Transpose 1", " Gain 1", " Transpose 2", " Gain 2", " Transpose 3", " Gain 3", " Portamento
Time", " Grain Size", " Rand. Timing %", " Randomize Pitch"];
target = [" ", "pshiftratio", "t1gain", "pshiftratio2", "t2gain", "pshiftratio3", "t3gain", "lagtime", "windowsize",
"timerandom", "prandomize"];
border = StaticText(mywindow, Rect(115,5, 140, 200)).background_(Color.new255(255,255,255));
border = StaticText(mywindow, Rect(5,5, 105, 200)).background_(Color.new255(255,255,255));
for(1,10, {arg counter;
StaticText(mywindow, Rect(6, (20*counter)-14, 103,
18)).background_(Gradient(Color.new255(basered+hilite,basegreen+hilite,baseblue+hilite),
Color.new255(basered,basegreen,baseblue), \v)).string_(textdesc[counter].asString);
pbox[counter] = NumberBox(mywindow, Rect(216,(20*counter)-14,38,
18)).background_(Gradient(Color.new255(basered+horizred+hilite,
basegreen+horizgreen+hilite,baseblue+horizblue+hilite),
Color.new255(basered+horizred,basegreen+horizgreen,baseblue+horizblue), \v));
pslid[counter] = SCSlider(mywindow, Rect(116,20*counter-14, 98,
18)).background_(Gradient(Color.new255(basered,basegreen,baseblue),
Color.new255(basered+horizred,basegreen+horizgreen,baseblue+horizblue),
\h)).thumbSize_(10).step_(1/96);
AppClock.sched(3, {
pslid[counter].action = {var susslid, symslid;
s.sendMsg(\n_set, 1990+3, \krate, 0);
learnslot = 2;
learnnum = counter-1;
fxstore[fxnum, counter-1] = pslid[counter].value; //store value for writing to preset array
slidval[counter] = ((pslid[counter].value)*scalefac[counter])+scalecons[counter];
case {counter == 2} {slidval[counter] = slidval[counter].ampdb;} //the following cases convert to dB for
Amp
{counter == 4 } {slidval[counter] = slidval[counter].ampdb;}
{counter == 6 } {slidval[counter] = slidval[counter].ampdb;};
pbox[counter].value = slidval[counter];
s.sendMsg(\n_set, 3026, target[counter].asSymbol, slidval[counter]);
midic.set(\fxslot, 1, \fxnum, counter);
//pshift.setn(target[counter].asSymbol, slidval[counter]);
}; //end slider action
});//end appclock
basered = basered-1;
basegreen = basegreen-1;
baseblue=baseblue+1;
pslid[counter].valueAction = 0.5;
}); // end counter loop
presponder = OSCresponder(s.addr, "fx26", {arg temp, value1, value2;
//"its here!".postln;
{for(1,10, {arg counter;
pslid[counter].value = value2[counter+2];
fxstore[fxnum, counter-1] = pslid[counter].value; //store value for writing to preset array
slidval[counter] = ((pslid[counter].value)*scalefac[counter])+scalecons[counter];
case {counter == 2} {slidval[counter] = slidval[counter].ampdb;} //the following cases
convert to dB for Amp
{counter == 4 } {slidval[counter] = slidval[counter].ampdb;}
{counter == 6 } {slidval[counter] = slidval[counter].ampdb;};
pbox[counter].value = slidval[counter];
s.sendMsg(\n_set, 3026, target[counter].asSymbol, slidval[counter]);
midic.set(\fxslot, 1, \fxnum, counter);
});
}.defer;
}).add;
CmdPeriod.doOnce({presponder.remove; mywindow.close});
}).send(s);
nil;
}); //schedule this synthdef to load after synthdefs are loaded
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//FX Slot 27 - Recorder (Buffer Suspend)
cbuffer = Buffer.alloc(s,(sr*30),1, bufnum: 11); //Use Buffer #11 for cbuff and #12 for cropped buffer!
SynthDef("CBuffer Reset", {arg buffertrigger=1;
//BufWr.ar(DC.ar(0.0), 11, Phasor.ar(0, BufRateScale.kr(0)), 0, BufFrames.kr(0));
cbuffer.sine1(0, false, false, true);
}).send(s);
SynthDef("CBuffer Record",{arg buffertrigger=1; var sig;
sig = InFeedback.ar(62);
RecordBuf.ar(sig, 11);
}).send(s);
//USES BUFFER #100+ for playback (copied/cropped buffer #11)
SynthDef("CBuffer Player",{arg buffertrigger=1, numbuffer=12, speed=1, envelope=0, length=1, startingplace=0;
Out.ar([37],
PlayBuf.ar(1, numbuffer,
BufRateScale.kr(numbuffer)*speed,
loop: 1, startPos: startingplace, doneAction:2)*(1envelope+(envelope*(abs(SinOsc.ar((0.5/length)), 0, 1)))))
}).send(s);
SynthDef("CBuffer Scratch", {arg buffertrigger=1, numbuffer=100, index=0.6, scratchtime=0.25; var fadein;
fadein = EnvGen.kr(Env([0, 0, 1], [0.2, 0.2])); // this synth needs a fade in because of buffer alloc noise
index = BufFrames.kr(numbuffer) * index * DC.ar(1);
Out.ar(37, fadein * BufRd.ar(1, numbuffer, Lag3.ar((index), scratchtime)));
}).send(s);
//---------------------------
//FX Slot 27 Recorder Buffer Gui
AppClock.sched(1, {
SynthDef("Crazy Buffer", {arg out=0; var tempout, buf, recordin, mywindow, startbutton,
playbutton, recnodeid, playnodeid, starttime, stoptime, length=1, count=100,
scratchslid,
scratchtime, scratchbox, scratchtimebox, lagtime, red,green,blue, failureprevent = 0,
fadeb,
envelope=0, isplaying=0, smalltext, fxnum=4, scratchresponder;
red = 127;
green = 142;
blue = 80;
mywindow = GUI.window.new("Recorder (27)", Rect(790, 265, 206, 95)).front;
mywindow.view.background = Color(0,0,0);
StaticText(mywindow, Rect(5,50, 195, 40)).background_(Color.new255(255,255,255));
StaticText(mywindow, Rect(37,30, 132, 20)).background_(Color.new255(255,255,255));
StaticText(mywindow, Rect(38,31, 130, 18)).background_(Color.new255(red,green,blue)).string_("
Scrubber");
StaticText(mywindow, Rect(130,5, 69, 20)).background_(Color.new255(255,255,255));
Buffer
smalltext = StaticText(mywindow, Rect(132,7, 45, 16)).background_(Color.new255(red,green,blue)).string_("
fades?");
smalltext.font = Font("Helvetica", 10);
smalltext = StaticText(mywindow, Rect(7,71, 65, 17)).background_(Color.new255(red,green,blue)).string_("
scratch lag:");
smalltext.font = Font("Helvetica", 10);
startbutton = Button(mywindow, Rect(5,5,60,20))
.states_([
["Record", Color.black, Color.new255(red,green,blue)],
["Stop", Color.black, Color.red]
]);
recnodeid = s.nextNodeID;
startbutton.action = {arg choice;
fxstore[fxnum, 0] = startbutton.value*2;
if (choice.value == 1, {
s.sendMsg(\n_free, 3027);
s.sendMsg("/s_new", "CBuffer Reset", s.nextNodeID, 1, 1);
starttime = Main.elapsedTime;
s.sendMsg("/s_new", "CBuffer Record", recnodeid, 1, 1);
},
{
failureprevent = 1;
stoptime = Main.elapsedTime;
length = stoptime-starttime;
length.postln;
susbuffer.free;
s.sendMsg("n_free", recnodeid);
count=count+1;
susbuffer = Buffer.alloc(s,sr*length, 1, bufnum: count);
cbuffer.copyData(susbuffer);
s.sendMsg("/s_new", "CBuffer Scratch", 3027, 1, 1, \numbuffer, count);
//s.sendMsg(\n_set, 3027, \numbuffer, count);
});
//end of record button actions
};
playbutton = Button(mywindow, Rect(65,5,60,20))
.states_([
["Play", Color.black, Color.new255(red, green, blue)],
["Stop", Color.black, Color.red]
]);
playnodeid = s.nextNodeID;
playbutton.action = {arg choice;
fxstore[fxnum, 1] = playbutton.value;
if (choice.value == 1, {s.sendMsg("/s_new", "CBuffer Player", playnodeid, 1, 1,
\numbuffer, count,
\envelope, envelope, \length, length); isplaying = 1;},
{s.sendMsg("n_free", playnodeid); isplaying = 0;});
};
scratchbox = NumberBox(mywindow, Rect(166, 51, 33, 18)).background_(Color.new255(red,green,blue));
scratchslid = SCSlider(mywindow, Rect(6,51, 158,
18)).background_(Color.new255(red,green,blue)).thumbSize_(10);
scratchslid.action = {arg phase;
learnslot = 3;
learnnum = 3;
fxstore[fxnum, 3] = scratchslid.value;
scratchbox.value = scratchslid.value;
if(failureprevent == 1, {s.sendMsg(\n_set, 3027, \index, scratchslid.value);}, {});
};
scratchslid.valueAction = 0.5;
scratchtimebox = NumberBox(mywindow, Rect(166, 71, 33, 18)).background_(Color.new255(red,green,blue));
scratchtime = SCSlider(mywindow, Rect(74,71, 90,
18)).background_(Color.new255(red,green,blue)).thumbSize_(10);
scratchtime.action = {arg phase;
learnslot = 3;
learnnum = 4;
fxstore[fxnum, 4] = scratchtime.value;
lagtime = scratchtime.value * 0.5;
scratchtimebox.value = lagtime;
if(failureprevent == 1, {s.sendMsg(\n_set, 3027, \scratchtime, lagtime);}, {});
};
scratchtime.valueAction = 0.5;
fadeb = Button(mywindow, Rect(182, 7, 15, 15)).states_([
["", Color.black, Color.new255(red, green, blue)],
["X", Color.black, Color.red]
]);
fadeb.action = {arg choice;
fxstore[fxnum, 2] = fadeb.value;
if (choice.value == 1, {envelope = 1;
if(isplaying == 1, {s.sendMsg(\n_set, playnodeid, \envelope, 1)}, {}); },
{envelope = 0;
if(isplaying == 1, {s.sendMsg(\n_set, playnodeid, \envelope, 0)}, {}); })};
scratchresponder = OSCresponder(s.addr, "fx27", {arg temp, value1, value2;
{if(value2[3] > 0.5, {value2[3] = 1}, {value2[3] = 0}); //to convert lagging values back to 1 or
0
if(value2[4] > 0.5, {value2[4] = 1}, {value2[4] = 0}); //to convert lagging values back to 1 or 0
if(value2[5] > 0.5, {value2[5] = 1}, {value2[5] = 0}); //to convert lagging values back to 1 or 0
startbutton.valueAction = value2[3];
playbutton.valueAction = value2[4];
fadeb.valueAction = value2[5];
scratchslid.valueAction = value2[6];
scratchtime.valueAction = value2[7];
}.defer;
}).add;
CmdPeriod.doOnce({scratchresponder.remove; mywindow.close});
}).send(s);
nil;
}); // end scheduler
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//FX Slot 28 Granulator
graindelbuf = Buffer.alloc(s,(sr*15),1, bufnum: 21); //Use Buffer #21 for all Grains Delay Buffer
grainenvbuf = CtkBuffer.new(bufnum: 22, size: 1024).fillWithEnv(env: Env([0,1,1,0],[0.5,0,0.5], \sin)).load;
//AppClock.sched(0.3, { //for initialization
graineng = SynthDef("Grain Engine", {arg out=0, deltime=0.1, rate=6, density=0.2, graindur=50, fades=0,
fadetime=0.05, gain=1;
var in, delayed = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], grained = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], tempout, tempout2, capture,
masterpulse30, tempL, tempR;
graindur = Lag.kr(graindur*(1/rate), 0.1);
in = InFeedback.ar(63);
capture = DelTapWr.ar(graindelbuf,in);
for(0,15, {arg counter;
delayed[counter] = DelTapRd.ar(graindelbuf, capture, ((counter+1)*Lag.kr(deltime,0.1)), 2);
//THE FOLLOWING LINE OF CODE CAUSES "RESULT = 0" THE FIRST TIME PATCH IS RUN?
grained[counter] = InGrainB.ar(CoinGate.ar(Lag.kr(density, 0.1), Impulse.ar(rate)), Lag.kr(graindur,0.1),
delayed[counter], 22);
});
tempout =
((grained[0]*0.95)+(grained[1]*0.05)+(grained[2]*0.9)+(grained[3]*0.1)+(grained[4]*0.85)+(grained[5]*0.15)+(grained[6]*
0.8)+(grained[7]*0.2)+
(grained[8]*0.75)+(grained[9]*0.25)+(grained[10]*0.7)+(grained[11]*0.3)+(grained[12]*0.65)+(grained[13]*0.35)+(
grained[14]*0.6)+(grained[15]*0.4));
tempout2 =
((grained[0]*0.05)+(grained[1]*0.95)+(grained[2]*0.1)+(grained[3]*0.9)+(grained[5]*0.85)+(grained[4]*0.15)+(grained[7]*
0.8)+(grained[6]*0.2)+
(grained[9]*0.75)+(grained[8]*0.25)+(grained[11]*0.7)+(grained[10]*0.3)+(grained[13]*0.65)+(grained[12]*0.35)+(
grained[15]*0.6)+(grained[14]*0.4));
tempL=tempout*Lag.kr(fades,fadetime)*gain;
tempR=tempout2*Lag.kr(fades,fadetime)*gain;
masterpulse30 = Impulse.kr(30);
SendReply.kr(masterpulse30, "outlevelL14", Amplitude.ar(tempL,0,1)); //Sets Meter sig, attack time, release time
SendReply.kr(masterpulse30, "outlevelR14", Amplitude.ar(tempR,0,1)); //Sets Meter sig, attack time, release
time
Out.ar(33, tempL);
Out.ar(34, tempR);
//Out.ar(0, [tempL, tempR]);
REMOVE WHEN DONE TESTING
Out.ar(38, (tempout+tempout2)*0.5);
}).send(s);
//nil;
//}); //end scheduling
//s.sendMsg("/s_new", "Grain Engine", 3028, 1, 1); // initialize Grain Engine
//------------Granulator Gui ----------------AppClock.sched(1.3, { //for initialization
SynthDef("Grain Gui", {arg out=0; var tempout, mywindow, grainbox = [0,0,0,0,0,0,0,0,0], grainslid = [0,0,0,0,0,0,0,0,0],
basered, basegreen, baseblue, border,
textdesc = Array.new(8), slidval = [0,0,0,0,0,0,0,0], fxnum=5, grainresponder;
mywindow = GUI.window.new("Granulator (28)", Rect(1001, 380, 260, 130)).front;
mywindow.view.background = Color(0,0,0);
basered=120;
basegreen=165;
baseblue=35;
textdesc = [" Grain Size %", " Grain Frequency", " Grain Density", " Max Grain Delay", " Grain Env Sus %", "
Grain Symmetry"];
border = StaticText(mywindow, Rect(115,5, 140, 120)).background_(Color.new255(255,255,255));
border = StaticText(mywindow, Rect(5,5, 105, 120)).background_(Color.new255(255,255,255));
for(1,6, {arg counter;
StaticText(mywindow, Rect(6, (20*counter)-14, 103, 18)).background_(Color.new255(basered, basegreen,
baseblue)).string_(textdesc[counter-1].asString);
grainbox[counter] = NumberBox(mywindow, Rect(216,(20*counter)-14,38,
18)).background_(Color.new255(basered, basegreen, baseblue));
grainslid[counter] = SCSlider(mywindow, Rect(116,20*counter-14, 98, 18)).background_(Color.new255(basered,
basegreen, baseblue)).thumbSize_(10);
grainslid[counter].action = {var susslid, symslid;
learnslot = 4;
learnnum = counter-1;
fxstore[fxnum, counter-1] = grainslid[counter].value; //store values so presets can be saved
slidval[counter] = grainslid[counter].value;
if(counter ==1, {
s.sendMsg(\n_set, 3028, \graindur, slidval[counter]);},{});
if(counter == 2, {
slidval[counter] =slidval[counter]*20; //grains per second
s.sendMsg(\n_set, 3028, \rate, slidval[counter]);},{});
if(counter == 3, {
slidval[counter] = slidval[counter]*slidval[counter]*20; //chance to make a given grain
s.sendMsg(\n_set, 3028, \density, slidval[counter]);},{});
if(counter == 4, {
slidval[counter] = slidval[counter]*slidval[counter]*15; //seconds through last grain delay (max 15)
s.sendMsg(\n_set, 3028, \deltime, (slidval[counter]/15));},{});
if(counter == 5, {
slidval[counter] = slidval[counter]*slidval[counter];
grainenvbuf.fillWithEnv(env: Env([0, 1, 1, 0], [((1-slidval[5].value)*(1-slidval[6].value)),
slidval[5].value, ((1-slidval[5].value)*(slidval[6].value))], \sin));
},{});
if(counter == 6, {
grainenvbuf.fillWithEnv(env: Env([0, 1, 1, 0], [((1-slidval[5].value)*(1-slidval[6].value)),
slidval[5].value, ((1-slidval[5].value)*(slidval[6].value))], \sin));
},{});
grainbox[counter].value = slidval[counter];
};
basered = basered-1;
basegreen = basegreen+2;
baseblue=baseblue+1;
grainslid[counter].valueAction = 0.5;
});
grainresponder = OSCresponder(s.addr, "fx28", {arg temp, value1, value2;
{for(1,6, {arg count;
grainslid[count].valueAction = value2[count+2];
});
}.defer;
}).add;
CmdPeriod.doOnce({grainresponder.remove; mywindow.close});
}).send(s);
nil;
}); // end scheduling
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//FX Slot 29+30 Ring Mod+ Freq Shift
ringmod1 = SynthDef("Ring Mod", {arg newfreq=500, changerate=10, freq=50; var input, tempout, ringfreq,
ringmodprocess;
tempout = InFeedback.ar(64);
tempout = tempout*SinOsc.ar(Lag.kr(freq, 0.1), 0, 1);
Out.ar([39], tempout);
}).send(s);
SynthDef("Freq Shift", {arg newfreq=500, changerate=10, freq=0; var input, tempout, ringfreq, ringmodprocess;
tempout = InFeedback.ar(65);
tempout = FreqShift.ar(tempout, Lag.kr(freq, 0.1));
Out.ar([40], tempout);
}).send(s);
// Ring Mod+Freq Shift Gui
AppClock.sched(1, {
SynthDef("Rind Mod Gui", {arg temp; var freq, ringslid, mywindow, ringnbox, slid, red, green, blue, red2, green2, blue2,
fsslid, fsbox, fs2slid, sign, rfmodresponder;
mywindow = GUI.window.new("Ring Modulator (29) + Freq Shifter (30)", Rect(60, 0, 1200, 50)).front;
mywindow.view.background = Color(0,0,0);
red = 183;
green = 159;
blue = 87;
red2 = 190;
green2 = 190;
blue2 = 60;
StaticText(mywindow, Rect(5, 5, 1190, 40)).background_(Color.new255(255,255,255));
StaticText(mywindow, Rect(6, 6, 78, 18)).background_(Color.new255(red, green, blue)).string_(" Ring Mod ");
StaticText(mywindow, Rect(6, 26, 78, 18)).background_(Color.new255(red2, green2, blue2)).string_(" Freq Shift ");
ringnbox = NumberBox(mywindow, Rect(1135,6,38,18)).background_(Color.new255(red,green,blue));
StaticText(mywindow, Rect(1175, 6, 19, 18)).background_(Color.new255(red, green, blue)).string_("Hz");
ringslid = SCSlider(mywindow,
Rect(86,6,1048,18)).background_(Color.new255(red,green,blue)).thumbSize_(10);
ringslid.action = {var slidfreq;
learnslot = 5;
learnnum = 0;
fxstore[6, 0] = ringslid.value; //store value for writing to preset array
slidfreq = (ringslid.value).squared*1500; //implement scaling function here
ringnbox.value = slidfreq;
s.sendMsg(\n_set, 3029, \freq, slidfreq);
};
ringslid.valueAction = 0.5;
fsbox = NumberBox(mywindow, Rect(1135,26,38,18)).background_(Color.new255(red2,green2,blue2));
StaticText(mywindow, Rect(1175, 26, 19, 18)).background_(Color.new255(red2, green2, blue2)).string_("Hz");
fsslid = SCSlider(mywindow,
Rect(86,26,1048,18)).background_(Color.new255(red2,green2,blue2)).thumbSize_(10);
fsslid.action = {var slidfreq;
learnslot = 5;
learnnum = 1;
fxstore[6, 1] = fsslid.value; //store value for writing to preset array
if(fsslid.value < 0.5, {sign = -1}, {sign = 1});
slidfreq = (fsslid.value-0.5).squared*4000*sign; //implement scaling function here
fsbox.value = slidfreq;
s.sendMsg(\n_set, 3030, \freq, slidfreq);
};
fsslid.valueAction = 0.5;
rfmodresponder = OSCresponder(s.addr, "fx29", {arg temp, value1, value2;
{ringslid.valueAction = value2[3];
fsslid.valueAction = value2[4];
}.defer;
}).add;
CmdPeriod.doOnce({rfmodresponder.remove; mywindow.close});
}).send(s);
nil;
}); //end scheduled initialization
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//FX Slot 31 Frequency Scrambling and Synth Convolution (uses BUS 68 internally)
SynthDef("Bin Scramble", {arg out=0, binpercentage=0.5, bindistance=0.1, changespeed=2; var chain, in;
in = InFeedback.ar(66);
chain = FFT(LocalBuf(fftbuffersize), in);
chain = PV_BinScramble(chain, binpercentage, bindistance, Impulse.kr(changespeed));
out = IFFT(chain);
//Above code is for scrambling bins, use in another effects slot with bin delay?
Out.ar(68, out);
}).send(s); //use Node #3031
SynthDef("Convolution", {arg out=0, synthfreq=400, frombinscramble=0, fromdry=1, binscrambleonly=0,
pitch1=48, gain1=0.25, pitch2=55, gain2=0.10, pitch3=64, gain3=0.1, pitch4=72, gain4=0.05, pitch5=79,
gain5=0.02; var tempout, kernel, in;
gain1 = gain1.dbamp;
gain2 = gain2.dbamp;
gain3 = gain3.dbamp;
gain4 = gain4.dbamp;
gain5 = gain5.dbamp;
in = (InFeedback.ar(66)*Lag.kr(fromdry, 0.5))+(InFeedback.ar(68)*Lag.kr(frombinscramble, 0.5));
kernel =(LFSaw.ar(pitch1.midicps,0,0.2)*gain1)+(LFSaw.ar(pitch2.midicps, 0, 0.2)*gain2)+
(LFSaw.ar(pitch3.midicps, 0, 0.2)*gain3)+(LFSaw.ar(pitch4.midicps, 0, 0.2)*gain4)+
(LFSaw.ar(pitch5.midicps, 0, 0.2)*gain5);
out = Convolution.ar(in, kernel, 1024, 0.5)*0.2;
Out.ar([41], (out*Lag.kr((1-binscrambleonly),0.5))+(InFeedback.ar(68)*Lag.kr(binscrambleonly,0.5)));
}).send(s); //use Node #4031
// ----- Convolution Gui
AppClock.sched(1, { //scheduling delayed initialization
SynthDef("Convolution Gui", {arg out;
var cslid = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], cnbox = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
textdesc, textset, binscramble, mywindow, red, green, blue, redchange, greenchange,
bluechange, red2, green2, blue2, label, multiplier, offset, convoVoffset = 90, binslid = [0,0,0,0,0],
binbox = [0,0,0,0,0,0], bindesc, binset, routingbutton, binmultiplier, binoffset, binon, binresponder,
conresponder;
red = 51;
green = 140;
blue = 110;
redchange = -1;
greenchange = 0;
bluechange = 1;
red2 = 195;
green2 = 80;
blue2 = 85;
textdesc = [" Pitch 1", " Gain 1", " Pitch 2", " Gain 2", " Pitch 3", " Gain 3", " Pitch 4", " Gain 4", " Pitch 5", " Gain
5"];
textset = ["pitch1", "gain1", "pitch2", "gain2", "pitch3", "gain3", "pitch4", "gain4", "pitch5", "gain5"];
multiplier = [24, 2, 24, 2, 24, 2, 24, 2, 24, 2];
offset = [36, 0, 43, 0, 52, 0, 60, 0, 67,0];
bindesc = ["Bin %", "Distance", "Update"];
binset = ["binpercentage", "bindistance", "changespeed"];
binmultiplier = [1, 0.3, 20];
binoffset = [0,0,0];
mywindow = GUI.window.new("FFT/Convol. (31)", Rect(790, 385, 206, 300)).front;
mywindow.view.background = Color(0,0,0);
StaticText(mywindow, Rect(5,5+convoVoffset,196,200)).background_(Color.new255(255,255,255));
StaticText(mywindow, Rect(5,5+25,196,60)).background_(Color.new255(255,255,255));
for(0, 9, {arg count;
label = StaticText(mywindow, Rect(6,
6+(count*20)+convoVoffset,45,18)).background_(Color.new255(red+(redchange*count),
green+(greenchange*count), blue+(bluechange*count))).string_(textdesc[count].asString);
cnbox[count] = NumberBox(mywindow, Rect(161, 6+(count*20)+convoVoffset, 40,
18)).background_(Color.new255(red+(redchange*count),
green+(greenchange*count), blue+(bluechange*count)));
cslid[count] = SCSlider(mywindow, Rect(53, 6+(count*20)+convoVoffset, 106,
18)).background_(Color.new255(red+(redchange*count),
green+(greenchange*count), blue+(bluechange*count))).thumbSize_(10).step_(1/96);
cslid[count].action = {arg test; var slidval;
learnslot = 7;
learnnum = count;
fxstore[8, count] = cslid[count].value; //store values so presets can be saved
slidval = ((test.value)*multiplier[count])+offset[count];
case {count == 1} {slidval = slidval.ampdb;} //the following cases convert to dB for Amp
{count == 3 } {slidval = slidval.ampdb;}
{count == 5 } {slidval = slidval.ampdb;}
{count == 7 } {slidval = slidval.ampdb;}
{count == 9 } {slidval = slidval.ampdb;};
cnbox[count].value = slidval;
s.sendMsg(\n_set, 4031, textset[count].asSymbol, slidval);
};
cslid[count].valueAction = 0.5;
});
routingbutton = SCButton(mywindow, Rect(5,5, 196, 20)).states_([
[" Bin Scramble Mode", Color.black, Color.new255(red2,green2,blue2)],
[" Convolution Mode", Color.black, Color.new255(red, green, blue)],
[" Bin Scramble + Convolution", Color.black, Color.new255((red2+red)*0.5,
(green+green2)*0.2,
(blue+blue2)*0.5)]]);
routingbutton.action = {arg choice;
fxstore[7, 4] = routingbutton.value;
case {choice.value == 0} {if(binon == 1, {}, {
s.sendMsg("/s_new", "Bin Scramble", 3031, 1, 1, \binpercentage,
binbox[0].value,
\bindistance, binbox[1].value, \changespeed, binbox[2].value);});
s.sendMsg(\n_set, 4031, \fromdry, 0, \frombinscramble, 1, \binscrambleonly,
1);
binon=1; }
{choice.value == 1} {s.sendMsg(\n_set, 4031, \fromdry, 1, \frombinscramble,
0,
\binscrambleonly, 0);
if(binon == 1, {s.sendMsg(\n_free, 3031)},{}); binon = 0; }
{choice.value == 2} {if(binon == 1, {}, {
s.sendMsg("/s_new", "Bin Scramble", 3031, 1, 1, \binpercentage,
binbox[0].value,
\bindistance, binbox[1].value, \changespeed, binbox[2].value);});
s.sendMsg(\n_set, 4031, \fromdry, 1, \frombinscramble, 1, \binscrambleonly,
0); binon = 1;}
};
routingbutton.valueAction = 1;
for(0,2, {arg count;
label = StaticText(mywindow, Rect(6,
6+(count*20)+25,45,18)).background_(Color.new255(red2+(redchange*count),
green2+(greenchange*count), blue2+(bluechange*count))).string_(bindesc[count].asString);
binbox[count] = NumberBox(mywindow, Rect(161, 6+(count*20)+25, 40,
18)).background_(Color.new255(red2+(redchange*count),
green2+(greenchange*count), blue2+(bluechange*count)));
binslid[count] = SCSlider(mywindow, Rect(53, 6+(count*20)+25, 106,
18)).background_(Color.new255(red2+(redchange*count),
green2+(greenchange*count), blue2+(bluechange*count))).thumbSize_(10).step_(1/96);
binslid[count].action = {arg test; var slidval;
learnslot = 6;
learnnum = count;
fxstore[7, count] = binslid[count].value; //store values so presets can be saved
slidval = ((test.value)*binmultiplier[count])+binoffset[count];
binbox[count].value = slidval;
if(binon == 1, {s.sendMsg(\n_set, 3031, binset[count].asSymbol, slidval);}, {});
};
binslid[count].valueAction = 0.5;
});
binresponder = OSCresponder(s.addr, "fx30", {arg temp, value1, value2;
number
{for(0,2, {arg count;
routingbutton.valueAction = value2[7];
binslid[count].valueAction = value2[count+3];
});
}.defer;
}).add;
//NOTE: binshift uses freqshift's fx
conresponder = OSCresponder(s.addr, "fx31", {arg temp, value1, value2;
{for(0,9, {arg count;
cslid[count].valueAction = value2[count+3];
});
}.defer;
}).add;
//Responder for Convolution
CmdPeriod.doOnce({binresponder.remove; conresponder.remove; mywindow.close});
}).send(s);
nil;
}); //end initialization
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//FX Slot 32 Reverb
reverbgen = SynthDef("Reverb", {arg roomsize=100, revtime=5, damping = 0.5, inputdamping=0.5, stereospread=0.6,
drylvl= 0,
earlyreflvl= -0.5, taillvl= -0.5, maxroomsize=110; var sig, sig3, sig4, stereo = [0,0], stereo2 = [0,0];
sig = InFeedback.ar(67);
stereo = GVerb.ar(sig, roomsize, revtime, damping, inputdamping, stereospread, drylvl, earlyreflvl, taillvl,
maxroomsize);
stereo2 = GVerb.ar(sig, roomsize*0.5, revtime*0.65, damping*0.8, inputdamping*0.9, stereospread, drylvl,
earlyreflvl, taillvl, maxroomsize*0.5);
Out.ar([42], (stereo[0]+stereo2[0])/2);
}).send(s);
//Reverb Gui ---------AppClock.sched(1, {
reverbgui = SynthDef("Reverb Gui", {arg out=0; var tempout, mywindow, rbox = [0,0,0,0,0,0,0,0,0,0,0,0,0,0], rslid =
[0,0,0,0,0,0,0,0,0,0,0,0,0],
basered, basegreen, baseblue, border, textdesc = Array.new(13), target = Array.new(13), slidval =
[0,0,0,0,0,0,0,0,0,0,0,0,0,0],
scalefac = [0, 20, 1, 1, 1],
scalecons = [0,0,0,0,0,0], initialize = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,], horizred, horizgreen, horizblue,
hilite, revresponder;
mywindow = GUI.window.new("Reverb (32)", Rect(1001, 265, 260, 90)).front;
mywindow.view.background = Color.new255(0,0,0);
basered=170;
basegreen=95;
baseblue=15;
horizred = 0; //horizred...etc is for a smilght darkening from left to right
horizgreen = 0;
horizblue = 0;
hilite = 10; //hilite is for a vertical highlight on the labels and number box (does not apply to slider)
textdesc = [" ", " Reverb Time", " Damping", " Input Bandwidth", " Stereo Spread"];
target = [" ", "revtime", "damping", "inputdamping", "stereospread"];
border = StaticText(mywindow, Rect(115,5, 140, 80)).background_(Color.new255(255,255,255));
border = StaticText(mywindow, Rect(5,5, 105, 80)).background_(Color.new255(255,255,255));
for(1,4, {arg counter;
StaticText(mywindow, Rect(6, (20*counter)-14, 103,
18)).background_(Gradient(Color.new255(basered+hilite,basegreen+hilite,baseblue+hilite),
Color.new255(basered,basegreen,baseblue), \v)).string_(textdesc[counter].asString);
rbox[counter] = NumberBox(mywindow, Rect(216,(20*counter)-14,38,
18)).background_(Gradient(Color.new255(basered+horizred+hilite,basegreen
+horizgreen+hilite,baseblue+horizblue+hilite),
Color.new255(basered+horizred,basegreen+horizgreen,baseblue+horizblue), \v));
rslid[counter] = SCSlider(mywindow, Rect(116,20*counter-14, 98,
18)).background_(Gradient(Color.new255(basered,basegreen,baseblue),
Color.new255(basered+horizred,basegreen+horizgreen,baseblue+horizblue), \h)).thumbSize_(10);
rslid[counter].action = {var susslid, symslid;
learnslot = 8;
learnnum = counter-1;
fxstore[9, counter] = rslid[counter].value;
slidval[counter] = ((rslid[counter].value)*scalefac[counter])+scalecons[counter];
rbox[counter].value = slidval[counter];
s.sendMsg(\n_set, 3032, target[counter].asSymbol, slidval[counter]);
//reverbgen.setn(target[counter].asSymbol, slidval[counter]);
}; //end slider action
basered = basered+5;
basegreen = basegreen+2;
baseblue=baseblue-2;
rslid[counter].valueAction = 0.5;
//schedule.sched(3, {rslid[counter].valueAction = 0.5;}); //this schedules initialization 0.5 seconds after loading
}); // end counter loop
revresponder = OSCresponder(s.addr, "fx32", {arg temp, value1, value2;
number
{for(1,4, {arg count;
rslid[count].valueAction = value2[count+3];
});
}.defer;
}).add;
//NOTE: binshift uses freqshift's fx
CmdPeriod.doOnce({revresponder.remove; mywindow.close});
}).send(s);
nil;
}); //end scheduling
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//Routing Matrix
//First make the actual routing function:
SynthDef("inputlink", {arg in=98, out=99, startfades=0, fades=1, triggerenv=1, fadetime=0.1;
Out.ar(out, EnvGen.kr(Env([startfades,fades],[fadetime]),triggerenv)*InFeedback.ar(in+50)); // The actual routing
takes place here
}).send(s);
for(1,18, {arg count;
//Then the main stereo bus routing function:
SynthDef("LR output"++count.asString, {arg in=98, out=99, fades=0, panning=0.5, volume=0, targetnum; var sig,
fadetime=0.1, masterpulse30;
sig = Pan2.ar(Lag.kr(fades, fadetime)*InFeedback.ar(in+50)*(Lag.kr(volume, fadetime)), (panning*2)-1);
masterpulse30 = Impulse.kr(30);
if(count != 11, {if(count != 14, {
SendReply.kr(masterpulse30, "outlevelL"++count.asString, Amplitude.ar(sig[0],0,1)); //Sets Meter sig, attack
time, release time
SendReply.kr(masterpulse30, "outlevelR"++count.asString, Amplitude.ar(sig[1],0,1)); //Sets Meter sig, attack
time, release time
}, {})});
Out.ar(out, sig);
}).send(s);
});
//Then make the overall synthdef for the router
routingmatrix = SynthDef("Routing Matrix", {arg test=0; var mywindow, harmshiftslid, delaytimeslid, feedbackslid,
rootpitchslid, tempsynth, row1, buttonfunc,
voffset = 20, routing, text1, text1call, border, textxpos, textypos, textlength, textheight, textred, textgreen,
textblue, textdesc, counter, skip = 5,
textredchange, textgreenchange, textbluechange, slid = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], outslid =
[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
resetbutton, lvlmapping1, lvlmapping2, lvlmapping3, outmeterL =
[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],outmeterR = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
buttonlist, panknob = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], pan1responder, pan2responder,
slid1responder, slid2responder, setresponder,
meter1responder, meter2responder, meter3responder;
//--------------------//the "lvlmapping1" function determines the routing coefficients for all input buses
lvlmapping1 = {arg lvl1=1, lvl2=1, lvl3=1, lvl4=1, lvl5=1, lvl6=1, lvl7=1, lvl8=1, lvl9=1, lvl10=1, lvl11=1, lvl12=1,
lvl13=1, lvl14=1, lvl15=1,
lvl16=1, lvl17=1, lvl18=1, audio1, lvl1imp, lvl1impdel;
/*NOTES: buses coming from sources into the matrix are numbered 23-32. Buses leaving FX are
numbered 35-42 internally. MAIN OUTS ARE BUSES 33-34.*/
//Input Metering
audio1 = [(SoundIn.ar(0)*lvl1), (SoundIn.ar(1)*lvl2), (SoundIn.ar(2)*lvl3), (SoundIn.ar(3)*lvl4),
(SoundIn.ar(4)*lvl5),(SoundIn.ar(5)*lvl6), (SoundIn.ar(6)*lvl7),
(SoundIn.ar(7)*lvl8), (InFeedback.ar(23)*lvl9), (InFeedback.ar(24)*lvl10), (InFeedback.ar(25)*lvl11),
(InFeedback.ar(26)*lvl12), (InFeedback.ar(27)*lvl13),
(InFeedback.ar(28)*lvl14), (InFeedback.ar(29)*lvl15), (InFeedback.ar(30)*lvl16),
(InFeedback.ar(31)*lvl17), (InFeedback.ar(32)*lvl18)];
Out.ar(50, audio1); //route all to 50
lvl1imp = Impulse.kr(30);
for(1,18, {
arg targetnum; var targetname;
targetname = "level"++targetnum.asString;
SendReply.kr(lvl1imp, targetname.asString, Amplitude.ar(audio1[targetnum-1],0,1)); //Sets Meter sig,
attack time, release time
});
}.play;
//-----------------------------------------------------------------------------------------------------//Now make the routing matrix window
mywindow = GUI.window.new("Routing Matrix", Rect(58, 75, 730, 400)).front;
mywindow.view.background = Color(0,0,0);
textxpos = 11;
textypos = 21;
textlength = 162;
textheight = 18;
textred = 120;
textgreen = 130;
textblue = 170;
textredchange = -2;
textgreenchange = -1;
textbluechange = 1;
textdesc = Array.new(16);
textdesc = [" Audio Input Channel 1", " Audio Input Channel 2", " Audio Input Channel 3", " Audio Input Channel
4", " Audio Input Channel 5",
" Audio Input Channel 6", " Audio Input Channel 7", " Audio Input Channel 8", " FX Bus 25 (Pattern
Delay)", " FX Bus 26 (Harmonizer)",
" FX Bus 27 (Recorder)", " FX Bus 28 (Granulator)"," FX Bus 29 (Ring Modulator)"," FX Bus 30 (Freq
Shifter)", " FX Bus 31 (FFT/Convolution)",
" FX Bus 32 (Reverb)"];
border = StaticText(mywindow, Rect(textxpos-1,textypos-1,textlength+2,(textheight
+2)*8)).background_(Color.new255(255,255,
255)); //white Border for Audio input text
border = StaticText(mywindow, Rect(textxpos-1,textypos1+(skip)+skip+((textheight+2)*10),textlength+2,(textheight+2)*8)).background_(Color.new255(255,
255,255)); //white border for FX sends text
border = StaticText(mywindow, Rect(textxpos-1,textypos1+(skip)+((textheight+2)*8),textlength+2,(textheight+2)*2)).background_(Color.new255(255,
255,255)); //white border wav player text
text1 = {arg xpos, ypos, length, height, red, green, blue, desc;
StaticText(mywindow,
Rect(xpos,ypos,length,height)).background_(Color.new255(red,green,blue)).string_(desc);
};
counter = 0;
while({counter < 8},
{
text1call =
text1.value(textxpos,textypos+(20*counter),textlength,textheight,textred+(counter*textredchange),textgreen+(counter*te
xtgreenchange),textblue+
(counter*textbluechange),textdesc[counter]);
counter = counter + 1;
};
);
//Make the wav player text windows
StaticText(mywindow, Rect(textxpos, textypos+skip+(160),
textlength,textheight)).background_(Color.new255(115,155,115)).string_("Wave Player L Channel");
StaticText(mywindow, Rect(textxpos, textypos+skip+(180),
textlength,textheight)).background_(Color.new255(115,155,115)).string_("Wave Player R Channel");
textred = 151;
textgreen = 131;
textblue = 147;
textredchange = 2;
textgreenchange = -2;
textbluechange = -2;
while({counter < 16},
{
text1call =
text1.value(textxpos,textypos+(20*(counter))+skip+45,textlength,textheight,textred+((counter)*textredchange),textgreen
+(textgreenchange*(counter)),
textblue+(textbluechange*(counter)),textdesc[counter]);
counter = counter + 1;
};
);
textred = 120;
textgreen = 130;
textblue = 170;
textredchange = -2;
textgreenchange = -1;
textbluechange = 1;
//function to generate all buttons/sliders/db boxes for routing matrix
buttonfunc = {arg foobar; var vertoffset = 20, horizoffset = 320, red, green, blue, redchange, greenchange,
bluechange,dim, slid1, slidxpos, slidwidth, slidheight,
slidthumbsize, lvlmeterwidth,buttonx, buttony, loopx, loopy, init;
red = textred;
green = textgreen;
blue = textblue;
redchange = textredchange;
greenchange = textgreenchange;
bluechange = textbluechange;
dim = 1.1;
slidxpos = 180;
slidwidth = 46;
slidheight = 20;
slidthumbsize = 10;
lvlmeterwidth = 40;
horizoffset = slidxpos+10+slidwidth+40+lvlmeterwidth;
border = StaticText(mywindow, Rect(slidxpos1,vertoffset,slidwidth+6+lvlmeterwidth+40,(textheight+2)*8)).background_(Color.new255(255,
255,255)); //white border background audio in slider
border = StaticText(mywindow, Rect(slidxpos1,vertoffset+5+(8*20),slidwidth+6+lvlmeterwidth+40,(textheight+2)*2)).background_(Color.new255(255,
255,255)); //white border background wav player text
border = StaticText(mywindow, Rect(slidxpos1,vertoffset+10+(10*20),slidwidth+6+lvlmeterwidth+40,(textheight+2)*8)).background_(Color.new255(255,
255,255)); //white border background audio in slider
//Below is the table of reserved nodes for matrix routing
buttonx = [1125, 1126, 1127, 1128, 1129, 1130, 1131, 1132, 1133, 1134, //audio input 1(0) routing nodes
1225, 1226, 1227, 1228, 1229, 1230, 1231, 1232, 1233, 1234, //audio 2(1) nodes
1325, 1326, 1327, 1328, 1329, 1330, 1331, 1332, 1333, 1334, //etc
1425, 1426, 1427, 1428, 1429, 1430, 1431, 1432, 1433, 1434,
1525, 1526, 1527, 1528, 1529, 1530, 1531, 1532, 1533, 1534,
1625, 1626, 1627, 1628, 1629, 1630, 1631, 1632, 1633, 1634,
1725, 1726, 1727, 1728, 1729, 1730, 1731, 1732, 1733, 1734,
1825, 1826, 1827, 1828, 1829, 1830, 1831, 1832, 1833, 1834, //audio input 8(7)
nodes
1101, 1102, 1103, 1104, 1105, 1106, 1107, 1108, 1109, 1110, //Wav L routing
nodes
1201, 1202, 1203, 1204, 1205, 1206, 1207, 1208, 1209, 1210,// Wav R routing
nodes
1111, 1112, 1113, 1114, 1115, 1116, 1117, 1118, 1119, 1120, //FX channel 1
routing nodes
1211, 1212, 1213, 1214, 1215, 1216, 1217, 1218, 1219, 1220, //FX channel 2
routing nodes
1311, 1313, 1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, //etc
1411, 1414, 1413, 1414, 1415, 1416, 1417, 1418, 1419, 1420,
1511, 1515, 1513, 1514, 1515, 1516, 1517, 1518, 1519, 1520,
1611, 1612, 1613, 1614, 1615, 1616, 1617, 1618, 1619, 1620,
1711, 1717, 1713, 1714, 1715, 1716, 1717, 1718, 1719, 1720,
1811, 1818, 1813, 1814, 1815, 1816, 1817, 1818, 1819, 1820; //FX channel 8
routing nodes
];
buttonlist = Array2D(18,9);
for(0,17, //y (vertical) axis loop start for drawing gui elements
{arg loopy; var snbox = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], meter = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
metertarget = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
outsnbox = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], outmetertargetL =
[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], outmetertargetR = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
lvltarget, vertbump=0, inoffset=0, lrsize, fxoffset=0, outputfaderoffset;
if(loopy==8, {red=115; green = 155; blue=115; redchange=0; greenchange=0; bluechange=0;
vertbump=5; inoffset=15});
if(loopy==9, {red=115; green = 162; blue=115; redchange=0; greenchange=0; bluechange=0;
vertbump=5;inoffset=15;});
if(loopy>9, {red=153; green=129; blue=151; redchange=2; greenchange= -2; bluechange= -2;
vertbump=10;inoffset=15});
if(loopy<10, {fxoffset=0;},{fxoffset=25;});
for(0,9, //x (horizontal) axis loop start for drawing gui elements
{arg loopx;
var label, horizbump=0, index=buttonx[loopx+(loopy*10)];
if(loopx<8, {label =(loopx+25).asString; horizbump=0; lrsize=0;}, //Displays Bus Number 25-32
{if(loopx<9,{label = "LR"; horizbump=5; lrsize=10},{})}); //Attaches "L"+"R" to main outs
if((loopy-10)==loopx, { //makes an unlabeled non-button so buses can't be fed back into
themselves
buttonlist[loopy,loopx] = Button(mywindow, Rect(horizoffset+(20*loopx)+horizbump,
vertoffset
+(loopy*20)+vertbump,20,20))
.states_([["", Color.black,
Color.new255(red+(loopy*redchange),green+(loopy*greenchange),blue+(loopy*bluechange))],["", Color.black,
Color.new255(red+(loopy*redchange),green+(loopy*greenchange),blue+(loopy*bluechange))]])}, {if(loopx < 8, {
buttonlist[loopy,loopx] = Button(mywindow, Rect(horizoffset+(20*loopx)+horizbump,vertoffset+(loopy*20)
+vertbump,20+lrsize,20))
.states_([[label.asString, Color.black,
Color.new255(red+(loopy*redchange),green+(loopy*greenchange),blue+(loopy*bluechange))],[label.asString,
Color.black, Color.red]]).action = {arg choice; var index=buttonx[loopx+(loopy*10)];
matrixstore[loopy,loopx] = buttonlist[loopy,loopx].value;
if (choice.value == 1, {s.sendMsg("/s_new", "inputlink", index, 1, 1, "in", (loopy-fxoffset),
"out", (loopx+25)); },
{s.sendMsg("n_free", index) } ) };
},//Makes and routes the non main-output buses
{
if(loopx<9,{ //this makes pairs of routing busses starting at 500 for LR out
s.sendMsg("/s_new", "LR output"++(loopy+1).asString, index, 1, 1, "in", (loopy-fxoffset), "out", (0));
buttonlist[loopy,loopx] = Button(mywindow, Rect(horizoffset+(20*loopx)+horizbump,vertoffset
+(loopy*20)+vertbump,20+lrsize,20))
.states_([[label.asString, Color.black,
Color.new255(red+(loopy*redchange),green+(loopy*greenchange),blue+(loopy*bluechange))],[label.asString,
Color.black, Color.red]]).action = {arg choice; matrixstore[loopy,loopx] =
buttonlist[loopy,loopx].value;
if (choice.value == 1, {
if(loopy == 13, {s.sendMsg(\n_set, 3028, \fades, 1)},{
if(loopy == 10, {s.sendMsg(\n_set, 4025, \fades, 1)}, {s.sendMsg("/n_set",
index, "fades", 1);});}); }, //end of "choice 1"
{if(loopy ==13,{s.sendMsg(\n_set, 3028, \fades,0) },{
if(loopy==10, {s.sendMsg(\n_set, 4025, \fades, 0)}, {s.sendMsg("/n_set",
index, "fades", 0);}) })} ) }; //LR for grain effect and stereo delay
},{};);});//Makes and routes the main output buses
});//end of if
};); //end of loopx
//this is for input faders/meters
snbox[loopy] = NumberBox(mywindow, Rect(slidxpos+1+slidwidth, vertoffset+1+(20*loopy)+vertbump,
40,18)).background_(Color.new255(red*dim+
(loopy*redchange),green*dim+(loopy*greenchange),blue*dim+(loopy*bluechange)));
slid[loopy] = SCSlider(mywindow, Rect(slidxpos, vertoffset+1+(loopy*20)+vertbump, slidwidth, slidheight2)).background_(Color.new255(red+
(loopy*redchange),green+(loopy*greenchange),blue+(loopy*bluechange))).thumbSize_(slidthumbsize);
slid[loopy].action = {var slidgain;
slidgain = (slid[loopy].value)*(slid[loopy].value)*2; //implement scaling function here
snbox[loopy].value = ampdb(slidgain);
lvltarget = "lvl"++(loopy+1).asString;
lvlmapping1.setn(lvltarget.asSymbol, slidgain); //so what's difference between "set" and "setn"?
};
meter[loopy] = SCLevelIndicator(mywindow, Rect(slidxpos+slidwidth+40, vertoffset+(20*loopy)+vertbump, 45,
20));
metertarget[loopy] = "level"++(loopy+1).asString;
meter1responder = OSCresponder(s.addr, metertarget[loopy].asSymbol, {arg time, resp, msg;
meter[loopy].value = msg[3].ampdb.linlin(-40,0,0,1);
}.defer
}).add;
meter[loopy].warning = -2.dbamp;
meter[loopy].critical = -1.dbamp;
{
//makes whitebackground for panning knobs & output faders/meters
StaticText(mywindow, Rect(horizoffset+200,
vertoffset+(loopy*20)+vertbump,107,20)).background_(Color.new255(255,255,255));
//this is for output faders/meters
outputfaderoffset = 356;
outsnbox[loopy] = NumberBox(mywindow, Rect(slidxpos+1+slidwidth+outputfaderoffset,
vertoffset+1+(20*loopy)+vertbump, 40,18))
.background_(Color.new255(red*dim+(loopy*redchange),green*dim+(loopy*greenchange),blue*dim+(loopy*blue
change)));
outslid[loopy] = SCSlider(mywindow, Rect(slidxpos+outputfaderoffset, vertoffset+1+(loopy*20)+vertbump,
slidwidth, slidheight-2))
.background_(Color.new255(red+(loopy*redchange),green+(loopy*greenchange),blue+(loopy*bluechange))).thu
mbSize_(slidthumbsize);
outslid[loopy].action = {var slidgain;
if(loopy < 10, {fxstore[10, loopy] = outslid[loopy].value;}, {fxstore[11, (loopy-10)] = outslid[loopy].value;}); //
store presets
slidgain = (outslid[loopy].value)*(outslid[loopy].value)*2; //implement scaling function here
outsnbox[loopy].value = ampdb(slidgain);
lvltarget = "lvl"++(loopy+1).asString;
if(loopy == 10, {s.sendMsg(\n_set, 4025, \gain, slidgain)},
{if(loopy == 13, {s.sendMsg(\n_set, 3028, \gain, slidgain)},
{s.sendMsg(\n_set, buttonx[(10*loopy)+8], "volume", slidgain);})});
};
outmeterL[loopy] = SCLevelIndicator(mywindow, Rect(slidxpos+slidwidth+40+outputfaderoffset,
vertoffset+(20*loopy)+vertbump, 50, 20));
outmeterR[loopy] = SCLevelIndicator(mywindow, Rect(slidxpos+slidwidth+40+outputfaderoffset+51,
vertoffset+(20*loopy)+vertbump, 50, 20));
outmetertargetL[loopy] = "outlevelL"++(loopy+1).asString;
outmetertargetR[loopy] = "outlevelR"++(loopy+1).asString;
meter2responder = OSCresponder(s.addr, outmetertargetL[loopy].asSymbol, {arg time, resp, msg;
{
outmeterL[loopy].value = msg[3].ampdb.linlin(-40,0,0,1);
}.defer
}).add;
meter3responder = OSCresponder(s.addr, outmetertargetR[loopy].asSymbol, {arg time, resp, msg;
{
outmeterR[loopy].value = msg[3].ampdb.linlin(-40,0,0,1);
}.defer
}).add;
outmeterL[loopy].warning = -2.dbamp;
outmeterL[loopy].critical = -1.dbamp;
outmeterR[loopy].warning = -2.dbamp;
outmeterR[loopy].critical = -1.dbamp;
//Makes panning knobs
StaticText(mywindow, Rect(horizoffset+200+1,
vertoffset+(loopy*20)+vertbump+1,18,18)).background_(Color.new255(red+(loopy*redchange),
green+(loopy*greenchange),blue+(loopy*bluechange)));
GUI.skins.default.knob.mySkin = ( );
GUI.skins.default.knob.mySkin.dial_(Color.new255(0,0,0)).center_(Color.new255(red+(loopy*redchange)+35,gre
en+(loopy*greenchange)+35,
blue+(loopy*bluechange)+35)).scale_(Color.new255(red+(loopy*redchange)60,green+(loopy*greenchange)-60,blue+(loopy*bluechange)-60)).level_(Color.new255(255,0,0));
//"If" turns off pan knobs for stereo output tracks
if(loopy == 10, {StaticText(mywindow, Rect(horizoffset+200+1, vertoffset+(loopy*20)+vertbump+1, 18,
18)).string_("NA");
panknob[loopy] = Knob.new(mywindow, Rect(0,0,0,0));},
{if(loopy == 13, {StaticText(mywindow, Rect(horizoffset+200+1, vertoffset+(loopy*20)+vertbump+1, 18,
18)).string_("NA");
panknob[loopy] = Knob.new(mywindow, Rect(0,0,0,0));},
{
panknob[loopy] = Knob.new(mywindow, Rect(horizoffset+200+1,
vertoffset+(loopy*20)+vertbump+1,18,18)).skin_(GUI.skins.default.knob.mySkin);
panknob[loopy].centered_(true);
panknob[loopy].action = {
if(loopy < 10, {fxstore[12, loopy] = panknob[loopy].value;}, {fxstore[13, (loopy-10)] =
panknob[loopy].value;}); // store presets
s.sendMsg("/n_set", buttonx[(10*loopy)+8], "panning", panknob[loopy].value);
};
if(loopy==8,{panknob[loopy].valueAction = 0;},{if(loopy==9,{panknob[loopy].valueAction = 1;},{
panknob[loopy].valueAction = 0.5;});
});
});
}); //end of if(loopy ==10
};);
//end of loopy
slid1responder = OSCresponder(s.addr, "matrixtop", {arg temp, value1, value2;
// responder for
setting presets
{for(0,9, {arg count;
outslid[count].valueAction = value2[count+3];
});
}.defer;
}).add;
slid2responder = OSCresponder(s.addr, "matrixbottom", {arg temp, value1, value2; //additional responder for
setting presets
{for(0,7, {arg count;
outslid[count+10].valueAction = value2[count+3];
});
}.defer;
}).add;
pan1responder = OSCresponder(s.addr, "pantop", {arg temp, value1, value2;
setting presets
{for(0,9, {arg count;
panknob[count].valueAction = value2[count+3];
});
}.defer;
}).add;
pan2responder = OSCresponder(s.addr, "panbottom", {arg temp, value1, value2;
setting presets
{for(0,7, {arg count;
panknob[count+10].valueAction = value2[count+3];
});
}.defer;
}).add;
// responder for
//additional responder for
resetbutton = Button(mywindow, Rect(10,10,10,10)).states_([["",Color.black,
Color,red],["",Color.black,Color.yellow]])
.action = {arg reset;
if(reset.value == 1, {
for(0,17,
{arg initall;
slid[initall].valueAction_(0.7071);
outslid[initall].valueAction_(0.7071);
if(initall == 8, {panknob[initall].valueAction_(0)},
{if(initall == 9, {panknob[initall].valueAction_(1)},
{panknob[initall].valueAction_(0.5);})});
});
resetbutton.value = 0;},{});
};
AppClock.sched(2, {resetbutton.valueAction = 1;
nil;}); //this schedules a manual fader reset to 0
};//End of Buttonfunc function
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//internal function to manage matrix routing
row1 = buttonfunc.value(99); //triggers the above function (routing matrix gui)
setresponder = OSCresponder(s.addr, "matrixset", {arg temp, value1, value2;
{//matrixlist =
Object.readArchive(presetdirectory.asString++p2directory++value1.asString++"matrix");
for(0,17, {arg county; //change back to 0,17
for(0,8, {arg countx; //change back to 0,8
//matrixlist[county,countx].postln;
buttonlist[county,countx].valueAction = matrixlist[county, countx];
})
});
}.defer;
}).add;
CmdPeriod.doOnce({pan1responder.remove; pan2responder.remove; slid1responder.remove;
slid2responder.remove; setresponder.remove; meter1responder.remove; meter2responder.remove;
meter3responder.remove; mywindow.close});
}).send(s);
//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------//-------------------------------------------------------------------------------------------------masterout = SynthDef("Master Stereo Out", {arg monitor; var level;
Out.ar([0], [InFeedback.ar(33)]);
Out.ar([1], [InFeedback.ar(34)]);
}).send(s);
AppClock.sched(0.5,{schedule.advance(3); //because of send(s) priority, this sets the faders to zero, .5 seconds after
loading
nil
});
AppClock.sched(0.5, {
synthcall = ["Pattern Delay Write","Delay On Off", "Pitch Shift", "Grain Engine", "Ring Mod", "Freq Shift", "Convolution",
"Reverb", "Master Stereo Out"];
synthnodes = [3025, 4025, 3026, 3028, 3029, 3030, 4031, 3032, 3033];
for(0, 8, {arg num;
s.sendMsg("/s_new", synthcall[num].asString, synthnodes[num], 1, 1);
//synthcall[num].post; " ".post; synthnodes[num].postln;
});
nil;
});//end appclock
)