Check out my work here
Bezier curves are really fun to use!
This is a dancer created with only lines. Simple, but it do looks like the little guy is dancing.
Code:
class LeoDancer {
constructor(startX, startY) {
this.x = startX;
this.y = startY;
this.ang = 0;
this.armArr = [-25, 20, -100, -35, 100, -25, 50, 15];
this.bodyArr = [0, -15, 0, -15, 0, 35, 0, 35];
this.leftFootArr = [0, 35, -15, 50, -25, 75, -25, 100];
this.rightFootArr = [0, 35, 15, 50, 25, 75, 25, 100];
// add properties for your dancer here:
//..
//..
//..
}
update() {
// update properties here to achieve
// your dancer's desired moves and behaviour
this.ang += 0.1 * random(0, 4);
//this.armArr.forEach((i,n,a)=>{a[n]=i+sin(this.ang)});
this.armArr[0] = -25 + sin(this.ang * 0.8) * 20;
this.armArr[1] = 15 + cos(this.ang * 0.5) * 5;
this.armArr[6] = 15 + map(sin(this.ang * 0.5), -1, 1, -20, 20);
this.armArr[7] = 15 + map(cos(this.ang * 0.5), -1, 1, -75, 20);
this.rightFootArr[6] = 25 + sin(this.ang * 0.5) * 15;
this.leftFootArr[6] = -25 - sin(this.ang * 0.1) * 15;
this.bodyArr[6] = sin(this.ang * 0.5) * 5;
this.leftFootArr[0] = sin(this.ang * 0.5) * 5;
this.rightFootArr[0] = sin(this.ang * 0.5) * 5;
}
display() {
// the push and pop, along with the translate
// places your whole dancer object at this.x and this.y.
// you may change its position on line 19 to see the effect.
push();
translate(this.x, this.y);
// ******** //
// ⬇️ draw your dancer here ⬇️
noFill();
stroke(255);
strokeWeight(4);
bezier(
this.armArr[0],
this.armArr[1],
this.armArr[2],
this.armArr[3],
this.armArr[4],
this.armArr[5],
this.armArr[6],
this.armArr[7],
);
bezier(
this.bodyArr[0],
this.bodyArr[1],
this.bodyArr[2],
this.bodyArr[3],
this.bodyArr[4],
this.bodyArr[5],
this.bodyArr[6],
this.bodyArr[7],
);
bezier(
this.leftFootArr[0],
this.leftFootArr[1],
this.leftFootArr[2],
this.leftFootArr[3],
this.leftFootArr[4],
this.leftFootArr[5],
this.leftFootArr[6],
this.leftFootArr[7],
);
bezier(
this.rightFootArr[0],
this.rightFootArr[1],
this.rightFootArr[2],
this.rightFootArr[3],
this.rightFootArr[4],
this.rightFootArr[5],
this.rightFootArr[6],
this.rightFootArr[7],
);
circle(cos(this.ang * 0.5) * 5, -45, 50);
// ⬆️ draw your dancer here ⬆️
// ******** //
// the next function draws a SQUARE and CROSS
// to indicate the approximate size and the center point
// of your dancer.
// it is using "this" because this function, too,
// is a part if your Dancer object.
// comment it out or delete it eventually.
this.drawReferenceShapes();
pop();
}
drawReferenceShapes() {
noFill();
stroke(255, 0, 0);
line(-5, 0, 5, 0);
line(0, -5, 0, 5);
stroke(255);
rect(-100, -100, 200, 200);
fill(255);
stroke(0);
}
}