+abstract class BlendTransition extends SCTransition {
+
+ final int blendType;
+
+ BlendTransition(GLucose glucose, int blendType) {
+ super(glucose);
+ this.blendType = blendType;
+ }
+
+ void computeBlend(int[] c1, int[] c2, double progress) {
+ if (progress < 0.5) {
+ for (int i = 0; i < c1.length; ++i) {
+ colors[i] = lerpColor(
+ c1[i],
+ blendColor(c1[i], c2[i], blendType),
+ (float) (2.*progress),
+ RGB);
+ }
+ } else {
+ for (int i = 0; i < c1.length; ++i) {
+ colors[i] = lerpColor(
+ c2[i],
+ blendColor(c1[i], c2[i], blendType),
+ (float) (2.*(1. - progress)),
+ RGB);
+ }
+ }
+ }
+}
+
+class MultiplyTransition extends BlendTransition {
+ MultiplyTransition(GLucose glucose) {
+ super(glucose, MULTIPLY);
+ }
+}
+
+class ScreenTransition extends BlendTransition {
+ ScreenTransition(GLucose glucose) {
+ super(glucose, SCREEN);
+ }
+}
+
+class BurnTransition extends BlendTransition {
+ BurnTransition(GLucose glucose) {
+ super(glucose, BURN);
+ }
+}
+
+class DodgeTransition extends BlendTransition {
+ DodgeTransition(GLucose glucose) {
+ super(glucose, DODGE);
+ }
+}
+
+class OverlayTransition extends BlendTransition {
+ OverlayTransition(GLucose glucose) {
+ super(glucose, OVERLAY);
+ }
+}
+
+class AddTransition extends BlendTransition {
+ AddTransition(GLucose glucose) {
+ super(glucose, ADD);
+ }
+}
+
+class SubtractTransition extends BlendTransition {
+ SubtractTransition(GLucose glucose) {
+ super(glucose, SUBTRACT);
+ }
+}
+
+class SoftLightTransition extends BlendTransition {
+ SoftLightTransition(GLucose glucose) {
+ super(glucose, SOFT_LIGHT);
+ }
+}
+
+class BassPod extends SCPattern {
+
+ private GraphicEQ eq = null;
+
+ public BassPod(GLucose glucose) {
+ super(glucose);
+ }
+
+ protected void onActive() {
+ if (eq == null) {
+ eq = new GraphicEQ(lx, 16);
+ eq.slope.setValue(0.6);
+ addParameter(eq.level);
+ addParameter(eq.range);
+ addParameter(eq.attack);
+ addParameter(eq.release);
+ addParameter(eq.slope);
+ }
+ }
+
+ public void run(double deltaMs) {
+ eq.run(deltaMs);
+
+ float bassLevel = eq.getAverageLevel(0, 5);
+
+ for (Point p : model.points) {
+ int avgIndex = (int) constrain(1 + abs(p.fx-model.xMax/2.)/(model.xMax/2.)*(eq.numBands-5), 0, eq.numBands-5);
+ float value = 0;
+ for (int i = avgIndex; i < avgIndex + 5; ++i) {
+ value += eq.getLevel(i);
+ }
+ value /= 5.;
+
+ float b = constrain(8 * (value*model.yMax - abs(p.fy-model.yMax/2.)), 0, 100);
+ colors[p.index] = color(
+ (lx.getBaseHuef() + abs(p.fy - model.cy) + abs(p.fx - model.cx)) % 360,
+ constrain(bassLevel*240 - .6*dist(p.fx, p.fy, model.cx, model.cy), 0, 100),
+ b
+ );
+ }
+ }
+}
+
+