OverlayUI ui;
ControlUI controlUI;
MappingUI mappingUI;
-PandaDriver pandaFront;
-PandaDriver pandaRear;
+PandaDriver[] pandaBoards;
boolean mappingMode = false;
-
-boolean pandaBoardsEnabled = false;
-
boolean debugMode = false;
DebugUI debugUI;
// Camera variables
float eyeR, eyeA, eyeX, eyeY, eyeZ, midX, midY, midZ;
-final float FEET = 12;
-
void setup() {
startMillis = lastMillis = millis();
logTime("Created viewport");
// Create the GLucose engine to run the cubes
- glucose = new GLucose(this, new SCMapping());
+ glucose = new GLucose(this, buildModel());
lx = glucose.lx;
lx.enableKeyboardTempo();
logTime("Built GLucose engine");
logTime("Built transitions");
// Build output driver
- int[][] frontChannels = glucose.mapping.buildFrontChannelList();
- int[][] rearChannels = glucose.mapping.buildRearChannelList();
- int[][] flippedRGB = glucose.mapping.buildFlippedRGBList();
- mappingTool = new MappingTool(glucose, frontChannels, rearChannels);
- pandaFront = new PandaDriver(new NetAddress("192.168.1.28", 9001), glucose.model, frontChannels, flippedRGB);
- pandaRear = new PandaDriver(new NetAddress("192.168.1.29", 9001), glucose.model, rearChannels, flippedRGB);
- logTime("Build PandaDriver");
+ PandaMapping[] pandaMappings = buildPandaList();
+ pandaBoards = new PandaDriver[pandaMappings.length];
+ int pbi = 0;
+ for (PandaMapping pm : pandaMappings) {
+ pandaBoards[pbi++] = new PandaDriver(pm.ip, glucose.model, pm);
+ }
+ mappingTool = new MappingTool(glucose, pandaMappings);
+ logTime("Built PandaDriver");
// Build overlay UI
ui = controlUI = new ControlUI();
mappingUI = new MappingUI(mappingTool);
- debugUI = new DebugUI(frontChannels, rearChannels);
+ debugUI = new DebugUI(pandaMappings);
logTime("Built overlay UI");
// MIDI devices
logTime("Setup MIDI devices");
// Setup camera
- midX = glucose.model.xMax/2 + 20;
+ midX = TRAILER_WIDTH/2. + 20;
midY = glucose.model.yMax/2;
- midZ = glucose.model.zMax/2;
- eyeR = -270;
+ midZ = TRAILER_DEPTH/2.;
+ eyeR = -290;
eyeA = .15;
eyeY = midY + 20;
eyeX = midX + eyeR*sin(eyeA);
endShape();
noStroke();
- fill(#292929);
+ fill(#393939);
drawBox(BASS_X, 0, BASS_Z, 0, 0, 0, BASS_WIDTH, BASS_HEIGHT, BASS_DEPTH, Cube.CHANNEL_WIDTH);
for (Cube c : glucose.model.cubes) {
drawCube(c);
// 2D Overlay
camera();
- javax.media.opengl.GL gl= ((PGraphicsOpenGL)g).beginGL();
+ javax.media.opengl.GL gl = ((PGraphicsOpenGL)g).beginGL();
gl.glClear(javax.media.opengl.GL.GL_DEPTH_BUFFER_BIT);
((PGraphicsOpenGL)g).endGL();
strokeWeight(1);
}
// TODO(mcslee): move into GLucose engine
- if (pandaBoardsEnabled) {
- pandaFront.send(colors);
- pandaRear.send(colors);
+ for (PandaDriver p : pandaBoards) {
+ p.send(colors);
}
}
void drawCube(Cube c) {
- drawBox(c.x, c.y, c.z, c.rx, c.ry, c.rz, Cube.EDGE_WIDTH, Cube.EDGE_HEIGHT, Cube.EDGE_WIDTH, Cube.CHANNEL_WIDTH);
+ float in = .15;
+ drawBox(c.x+in, c.y+in, c.z+in, c.rx, c.ry, c.rz, Cube.EDGE_WIDTH-in*2, Cube.EDGE_HEIGHT-in*2, Cube.EDGE_WIDTH-in*2, Cube.CHANNEL_WIDTH-in);
}
void drawBox(float x, float y, float z, float rx, float ry, float rz, float xd, float yd, float zd, float sw) {
pushMatrix();
translate(x, y, z);
- rotate(rx, 1, 0, 0);
+ rotate(rx / 180. * PI, -1, 0, 0);
rotate(ry / 180. * PI, 0, -1, 0);
- rotate(rz, 0, 0, 1);
+ rotate(rz / 180. * PI, 0, 0, -1);
for (int i = 0; i < 4; ++i) {
float wid = (i % 2 == 0) ? xd : zd;
}
break;
case 'p':
- pandaBoardsEnabled = !pandaBoardsEnabled;
- println("PandaBoard Output: " + (pandaBoardsEnabled ? "ON" : "OFF"));
+ for (PandaDriver p : pandaBoards) {
+ p.toggle();
+ }
break;
case 'u':
uiOn = !uiOn;
}
int mx, my;
-
void mousePressed() {
- if (mouseX > ui.leftPos) {
- ui.mousePressed();
- } else {
+ ui.mousePressed();
+ if (mouseX < ui.leftPos) {
if (debugMode) {
debugUI.mousePressed();
}
}
void mouseReleased() {
- if (mouseX > ui.leftPos) {
- ui.mouseReleased();
- }
+ ui.mouseReleased();
}
void mouseWheel(int delta) {
- eyeR = constrain(eyeR - delta, -500, -80);
- eyeX = midX + eyeR*sin(eyeA);
- eyeZ = midZ + eyeR*cos(eyeA);
+ if (mouseX > ui.leftPos) {
+ ui.mouseWheel(delta);
+ } else {
+ eyeR = constrain(eyeR - delta, -500, -80);
+ eyeX = midX + eyeR*sin(eyeA);
+ eyeZ = midZ + eyeR*cos(eyeA);
+ }
}