/**
* Engine construction and initialization.
*/
-LXPattern[] _patterns(GLucose glucose) {
+
+LXTransition _transition(GLucose glucose) {
+ return new DissolveTransition(glucose.lx).setDuration(1000);
+}
+
+LXPattern[] _leftPatterns(GLucose glucose) {
LXPattern[] patterns = patterns(glucose);
for (LXPattern p : patterns) {
- p.setTransition(new DissolveTransition(glucose.lx).setDuration(1000));
+ p.setTransition(_transition(glucose));
}
return patterns;
}
+LXPattern[] _rightPatterns(GLucose glucose) {
+ LXPattern[] patterns = _leftPatterns(glucose);
+ LXPattern[] rightPatterns = new LXPattern[patterns.length+1];
+ int i = 0;
+ rightPatterns[i++] = new BlankPattern(glucose).setTransition(_transition(glucose));
+ for (LXPattern p : patterns) {
+ rightPatterns[i++] = p;
+ }
+ return rightPatterns;
+}
+
+
void logTime(String evt) {
int now = millis();
println(evt + ": " + (now - lastMillis) + "ms");
// Set the patterns
Engine engine = lx.engine;
- engine.setPatterns(patterns = _patterns(glucose));
- engine.addDeck(_patterns(glucose));
+ engine.setPatterns(patterns = _leftPatterns(glucose));
+ engine.addDeck(_rightPatterns(glucose));
logTime("Built patterns");
glucose.setTransitions(transitions(glucose));
logTime("Built transitions");
popMatrix();
noStroke();
-// drawBassBox(glucose.model.bassBox);
-// for (Speaker s : glucose.model.speakers) {
-// drawSpeaker(s);
-// }
+ if (glucose.model.bassBox.exists) {
+ drawBassBox(glucose.model.bassBox, false);
+ }
+ for (Speaker speaker : glucose.model.speakers) {
+ drawSpeaker(speaker);
+ }
for (Cube c : glucose.model.cubes) {
drawCube(c);
}
noFill();
strokeWeight(2);
beginShape(POINTS);
- // TODO(mcslee): restore when bassBox/speakers are right again
- // for (Point p : glucose.model.points) {
- for (Cube cube : glucose.model.cubes) {
- for (Point p : cube.points) {
- stroke(colors[p.index]);
- vertex(p.fx, p.fy, p.fz);
- }
+ for (Point p : glucose.model.points) {
+ stroke(colors[p.index]);
+ vertex(p.fx, p.fy, p.fz);
}
endShape();
}
}
-void drawBassBox(BassBox b) {
+void drawBassBox(BassBox b, boolean hasSub) {
+
float in = .15;
-
- noStroke();
- fill(#191919);
- pushMatrix();
- translate(b.x + BassBox.EDGE_WIDTH/2., b.y + BassBox.EDGE_HEIGHT/2, b.z + BassBox.EDGE_DEPTH/2.);
- box(BassBox.EDGE_WIDTH-20*in, BassBox.EDGE_HEIGHT-20*in, BassBox.EDGE_DEPTH-20*in);
- popMatrix();
+
+ if (hasSub) {
+ noStroke();
+ fill(#191919);
+ pushMatrix();
+ translate(b.x + BassBox.EDGE_WIDTH/2., b.y + BassBox.EDGE_HEIGHT/2, b.z + BassBox.EDGE_DEPTH/2.);
+ box(BassBox.EDGE_WIDTH-20*in, BassBox.EDGE_HEIGHT-20*in, BassBox.EDGE_DEPTH-20*in);
+ popMatrix();
+ }
noStroke();
fill(#393939);
case '=':
case '+':
frameRate(++targetFramerate);
- break;
+ break;
+ case 'b':
+ EFF_boom.trigger();
+ break;
case 'd':
if (!midiEngine.isQwertyEnabled()) {
debugMode = !debugMode;