pakt21
See /software/p5js/pakt-februari/pakt21/ for a JavaScript version and /software/supercollider/februari-pakt/pakt21/ for accompanying sound code.
#include "cinder/app/App.h"
#include "cinder/cairo/Cairo.h"
using namespace ci;
using namespace ci::app;
using namespace std;
const int WIDTH= 640;
const int HEIGHT= 480;
class pakt21App : public App {
public:
void setup();
void draw();
cairo::SurfaceImage srfOff;
cairo::Context ctxOff;
int index, n;
float w, h;
vector<vec2> last;
vector<Color> cols;
};
void pakt21App::setup() {
srfOff= cairo::SurfaceImage(WIDTH, HEIGHT, false);
ctxOff= cairo::Context(srfOff);
ctxOff.setSourceRgb(0, 0, 0);
ctxOff.paint();
n= 150;
index= 0;
for(int i= 0; i<n; i++) {
float t= float(i)/n*M_PI*2;
last.push_back(vec2(0.0f, 0.0f));
cols.push_back(Color(sin(t)*0.5f+0.5f, sin(t+M_PI)*0.5f+0.5f, 1.0f));
}
w= getWindowWidth();
h= getWindowHeight();
}
void pakt21App::draw() {
cairo::Context ctx(cairo::createWindowSurface());
ctxOff.setSourceRgba(0, 0, 0, 0.05);
ctxOff.paint();
for(int i= 0; i<n; i++) {
float x= sin((i*(sin(index*0.0126f+(sin(i)*sin(i*2)))*sin(index*0.0031f))+index)*0.074f);
float y= cos((i*(sin(index*0.0152f+(sin(i)*sin(i*2)))*sin(index*0.0021f))+index)*0.064f);
vec2 pos= vec2(x*w*0.45f+(w*0.5f), y*h*0.45f+(h*0.5f));
if(index>0) {
ctxOff.setSourceRgb(cols[i].r, cols[i].g, cols[i].b);
ctxOff.circle(pos, abs((pos.x-last[i].x)+(pos.y-last[i].y))*0.5f);
ctxOff.fill();
}
last[i]= pos;
}
index++;
ctx.copySurface(srfOff, srfOff.getBounds());
}
CINDER_APP(pakt21App, Renderer2d, [&]( App::Settings *settings ) {
settings->setWindowSize( WIDTH, HEIGHT );
settings->setResizable( false );
})