xxxxxxxxxx
67
// Daniel Shiffman
// https://thecodingtrain.com/CodingChallenges/024-perlinnoiseflowfield.html
var inc = 0.1;
var scl = 10;
var cols, rows;
var zoff = 0;
var fr;
var particles = [];
var flowfield;
function setup() {
createCanvas(600, 400);
cols = floor(width / scl);
rows = floor(height / scl);
fr = createP('');
flowfield = new Array(cols * rows);
for (var i = 0; i < 1000; i++) {
console.log(i);
particles[i] = new Particle();
}
background(255);
}
function draw() {
// background(51);
var yoff = 0;
for (var y = 0; y < rows; y++) {
var xoff = 0;
for (var x = 0; x < cols; x++) {
var index = x + y * cols;
// var angle= sin(x * 0.01) + sin(y * 0.01)*(PI * 2)
var angle = noise(xoff, yoff, zoff) * TWO_PI ;
var v = p5.Vector.fromAngle(angle);
v.setMag(1);
flowfield[index] = v;
xoff += inc;
stroke(0, 50);
// push();
// translate(x * scl, y * scl);
// rotate(v.heading());
// strokeWeight(1);
// line(0, 0, scl, 0);
// pop();
}
yoff += inc;
zoff += 0.0003;
}
for (var i = 0; i < particles.length; i++) {
particles[i].follow(flowfield);
particles[i].update();
particles[i].edges();
particles[i].show();
}
// fr.html(floor(frameRate()));
}