boolean btwn (double a,double b,double c) { return a >= b && a <= c; }
public class Pick {
- Pick (String label, int _Def, int _Max) { NumPicks=_Max; Default = _Def; tag=label; }
+ Pick (String label, int _Def, int _Max, String d[]) { NumPicks=_Max; Default = _Def; tag=label; Desc = d; }
int Cur() { return (CurRow-StartRow)*NumApcCols + CurCol; }
int NumPicks, Default, CurRow, CurCol, StartRow, EndRow;
- String tag;
+ String Desc[] ;
+ String tag ;
}
//----------------------------------------------------------------------------------------------------------------------------------
public class _DhP extends BasicParameter {
- double dflt;
+ double dflt;
_DhP (String label, double value) { super(label,value); dflt=value; }
- void Set (double value) { super.updateValue(value); }
- void reset () { super.updateValue(dflt); }
+ void Set (double value) { super.setValue(value); }
+ void reset () { super.setValue(dflt); }
float Val () { return getValuef(); }
boolean ZeroOrOne () { return Val()==0 || Val() == 1; }
}
xyz(float _x,float _y,float _z) {x=_x ; y=_y ; z=_z ;}
void set(Point p ) {x=p.fx ; y=p.fy; z=p.fz;}
void set(float _x,float _y,float _z) {x=_x ; y=_y ; z=_z ;}
- float distance(xyz b) {return dist(x,y,z,b.x,b.y,b.z); }
- float dot (xyz b) {return x*b.x + y*b.y + z*b.z; }
- xyz minus (xyz b) {return new xyz(x-b.x,y-b.y,z-b.z); }
- xyz plus (xyz b) {return new xyz(x+b.x,y+b.y,z+b.z); }
- xyz plus (float b) {return new xyz(x+b ,y+b ,z+b ); }
- xyz over (xyz b) {return new xyz(x/b.x,y/b.y,z/b.z); }
- xyz times (float b) {return new xyz(x*b ,y*b ,z*b ); }
-
- xyz RotateX (xyz o, float a) { return new xyz ( x,
- cos(a)*(y-o.y) - sin(a)*(z-o.z) + o.y,
- sin(a)*(y-o.y) + cos(a)*(z-o.z) + o.z); }
-
- xyz RotateY (xyz o, float a) { return new xyz ( cos(a)*(x-o.x) - sin(a)*(z-o.z) + o.x,
- y,
- sin(a)*(x-o.x) + cos(a)*(z-o.z) + o.z); }
-
- xyz RotateZ (xyz o, float a) { return new xyz ( cos(a)*(x-o.x) - sin(a)*(y-o.y) + o.x,
- sin(a)*(x-o.x) + cos(a)*(y-o.y) + o.y,
- z ); }
-
+ float distance(xyz b) {return dist(x,y,z,b.x,b.y,b.z); }
+ float dot (xyz b) {return x*b.x + y*b.y + z*b.z; }
+ xyz minus (xyz b) {return new xyz(x-b.x,y-b.y,z-b.z); }
+ xyz plus (xyz b) {return new xyz(x+b.x,y+b.y,z+b.z); }
+ xyz plus (float b) {return new xyz(x+b ,y+b ,z+b ); }
+ xyz over (xyz b) {return new xyz(x/b.x,y/b.y,z/b.z); }
+ xyz times (float b) {return new xyz(x*b ,y*b ,z*b ); }
+ boolean isZero () {return x==0 && y==0 && z==0; }
+
+ void RotateZ (xyz o, float nSin, float nCos) {
+ float nX = nCos*(x-o.x) - nSin*(y-o.y) + o.x;
+ float nY = nSin*(x-o.x) + nCos*(y-o.y) + o.y;
+ x = nX; y = nY;
+ }
- void RotateXYZ (xyz o, xyz t, xyz tsin, xyz tcos) {
- { x -= o.x; y -= o.y; z -= o.z; }
- if (t.x != 0) { y = y*tcos.x - z*tsin.x; z = y*tsin.x + z*tcos.x; }
- if (t.y != 0) { z = z*tcos.y - x*tsin.y; x = z*tsin.y + x*tcos.y; }
- if (t.z != 0) { x = x*tcos.z - y*tsin.z; y = x*tsin.z + y*tcos.z; }
- { x += o.x; y += o.y; z += o.z; }
+ void RotateX (xyz o, float nSin, float nCos) {
+ float nY = nCos*(y-o.y) - nSin*(z-o.z) + o.y;
+ float nZ = nSin*(y-o.y) + nCos*(z-o.z) + o.z;
+ y = nY; z = nZ;
+ }
+ void RotateY (xyz o, float nSin, float nCos) {
+ float nZ = nCos*(z-o.z) - nSin*(x-o.x) + o.z;
+ float nX = nSin*(z-o.z) + nCos*(x-o.x) + o.x;
+ z = nZ; x = nX;
}
xyz setRand () { return new xyz ( random(xdMax), random(ydMax), random(zdMax)); }
int mapRow (int a) { return btwn(a,53,57) ? a-53 : a; }
int unmapRow (int a) { return btwn(a,0 , 4) ? a+53 : a; }
+
void SetLight (int row, int col, int clr){ if (APCOut != null) APCOut.sendNoteOn(col, unmapRow(row), clr); }
+ void SetKnob (int cc , int chan,int val){ if (APCOut != null) APCOut.sendController(cc , chan , val); }
float _Trails () { return Sliders[0]; }
float _Dim () { return Sliders[1]; }
for (MidiInputDevice input : RWMidi.getInputDevices ()) {
if (input.toString().contains("APC")) input.createInput (this);
}
- }
+ }
void SetText()
{
Text1 += " ZSym: " + (_ZSym ? "ON" : "OFF") + " ";
Text1 += " RSym: " + (_RSym ? "ON" : "OFF") + " ";
for (int i=0; i<CurPat.picks.size(); i++) {
- Pick P = (Pick)CurPat.picks.get(i); Text1 += P.tag + ": " + P.Cur() + " ";
+ Pick P = (Pick)CurPat.picks.get(i); Text1 += P.tag + ": " + P.Desc[P.Cur()] + " ";
}
Text2 = "SLIDERS: ";
- for (int i=0; i<8; i++) if (SliderText[i] != "") { Text2 += SliderText[i] + ": " + Sliders[i] + " "; }
+ for (int i=0; i<8; i++) if (SliderText[i] != "") {
+ Text2 += SliderText[i] + ": " + int(100*Sliders[i]) + " "; }
uiDebugText.setText(Text1, Text2);
}
void controllerChangeReceived(rwmidi.Controller cc) {
if (cc.getCC() == 7 && btwn(cc.getChannel(),0,7)) { Sliders[cc.getChannel()] = 1.*cc.getValue()/127.; }
-
else if (cc.getCC() == 15 && cc.getChannel() == 0) {
lx.engine.getDeck(1).getCrossfader().setValue( 1.*cc.getValue()/127.);
}
//else { println(cc.getCC() + " " + cc.getChannel() + " " + cc.getValue()); }
}
-
+
void Deactivate (DPat p) { if (p == CurPat) { uiDebugText.setText(""); CurPat = NextPat; } NextPat = null; }
void Activate (DPat p) {
NextPat = CurPat; CurPat = p;
void UpdateLights() {
for (int i=0; i<NumApcRows ; i++) for (int j=0; j<NumApcCols; j++) SetLight(i, j, 0);
+ for (int i=48;i< 56 ; i++) SetKnob(0, i, 0);
+ for (int i=16;i< 20 ; i++) SetKnob(0, i, 0);
for (int i=0; i<CurPat.picks.size() ; i++) {
Pick P = (Pick)CurPat.picks.get(i); SetLight(P.CurRow, P.CurCol, 3);
}
SetLight(83, 0, _YSym ? 3 : 0);
SetLight(84, 0, _ZSym ? 3 : 0);
SetLight(85, 0, _RSym ? 3 : 0);
+
+ for (int i=0; i<CurPat.paramlist.size(); i++) {
+ _DhP Param = (_DhP)CurPat.paramlist.get(i);
+ SetKnob ( 0, i<=55 ? 48+i : 16 + i - 8, int(Param.Val()*127) );
+ }
}
double Tap1 = 0;
double getNow() { return millis() + 1000*second() + 60*1000*minute() + 3600*1000*hour(); }
-
void noteOffReceived(Note note) {
if (CurPat == null) return;
int row = DG.mapRow(note.getPitch()), col = note.getChannel();
if (!btwn((row-P.StartRow)*NumApcCols + col,0,P.NumPicks-1) ) continue;
P.CurRow=row; P.CurCol=col; return;
}
- println(row + " " + col);
+ //println(row + " " + col);
}
}
}
int nMaxRow = 0;
float zSpinHue = 0;
int nPoint , nPoints;
- xyz xyzHalf = new xyz(.5,.5,.5),
- xyzdMax,
- xyzMid;
+ xyz xyzHalf = new xyz(.5,.5,.5),
+ xyzdMax = new xyz(),
+ xyzMid = new xyz();
float NoiseMove = random(10000);
- _DhP pSharp;
-
+ _DhP pSharp, pRotX, pRotY, pRotZ;
float Dist (xyz a, xyz b) { return dist(a.x,a.y,a.z,b.x,b.y,b.z); }
int c1c (float a) { return int(100*constrain(a,0,1)); }
float CalcCone (xyz v1, xyz v2, xyz c) { return degrees( acos ( v1.minus(c).dot(v2.minus(c)) /
paramlist.add(P); return P;
}
- Pick addPick(String name, int def, int nmax) {
- Pick P = new Pick(name, def, nmax);
+ Pick addPick(String name, int def, int nmax, String[] desc) {
+ Pick P = new Pick(name, def, nmax, desc);
P.StartRow = nMaxRow;
P.EndRow = P.StartRow + int((nmax-1) / NumApcCols);
nMaxRow = P.EndRow + 1;
DPat(GLucose glucose) {
super(glucose);
DG.Init();
- pSharp = addParam("Shrp", 0);
+ pSharp = addParam("Shrp" , 0);
nPoints = model.points.size();
xdMax = model.xMax;
ydMax = model.yMax;
xyz P = new xyz();
float modhue = DG._ModHue ()==0 ? 0 : DG._ModHue ()*360;
float fSharp = 1/(1.01-pSharp.Val());
-
+
DG.SetText();
nPoint = 0;
for (Point p : model.points) { nPoint++;