Files
2021-06-07 00:02:33 -05:00

92 lines
2.1 KiB
JavaScript

//////////////////////////////////
// COURSERA GRAPHICS PROGRAMMING
//////////////////////////////////
// Adapted from https://github.com/nature-of-code/
// released under MIT license
var ball;
///////////////////////////////////////////////
function setup() {
createCanvas(600, 400);
balls = [];
}
///////////////////////////////////////////////
function draw() {
background(0);
let gravity = createVector(0, 0.1);
for (let i = 0; i < balls.length; i++) {
let ball = balls[i];
let friction = ball.velocity.copy();
friction.mult(-1);
friction.normalize();
friction.mult(0.01);
let momentum = new createVector(width/2 - mouseX, height/2 - mouseY);
momentum.normalize();
momentum.mult(0.1);
ball.applyForce(gravity);
ball.applyForce(friction);
ball.applyForce(momentum);
ball.run();
}
}
function mouseClicked() {
//ball.location = new createVector(width / 2, height / 2);
}
function mouseDragged() {
if(mouseButton === LEFT)
balls.push(new Ball(mouseX, mouseY));
else
balls = [];
}
///////////////////////////////////////////////
class Ball {
constructor(x, y) {
this.acceleration = new createVector(0, 0);
this.velocity = new createVector(random(-3, 3), random(-3, 3));
this.location = new createVector(x, y);
this.size = random (10, 60);
}
run() {
this.draw();
this.move();
this.bounce();
}
draw() {
fill(125);
ellipse(this.location.x, this.location.y, this.size, this.size);
}
move() {
this.velocity.add(this.acceleration);
this.location.add(this.velocity);
this.acceleration.mult(0);
}
bounce() {
if (this.location.x > width - this.size / 2) {
this.location.x = width - this.size / 2;
this.velocity.x *= -1;
} else if (this.location.x < this.size / 2) {
this.velocity.x *= -1;
this.location.x = this.size / 2;
}
if (this.location.y > height - this.size / 2) {
this.velocity.y *= -1;
this.location.y = height - this.size / 2;
}
}
applyForce(force) {
this.acceleration.add(force);
}
}