-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathemojipocalypse.js
82 lines (73 loc) Β· 1.96 KB
/
emojipocalypse.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
const canvasSketch = require('canvas-sketch');
const { linspace, mapRange } = require('canvas-sketch-util/math');
const Random = require('canvas-sketch-util/random');
const { fun } = require('./emoji');
const settings = {
dimensions: [1080, 1080],
animate: true,
duration: 10,
scaleToView: true,
};
const sketch = () => {
console.clear();
let curves;
Random.setSeed(Random.getRandomSeed());
return {
begin({ context, width, height }) {
curves = linspace(128 * 6).map(
(_, idx) =>
new Lissajous(
[width / 2, height / 2],
width * 0.5,
[Random.rangeFloor(1, 3), Random.rangeFloor(1, 3)],
[Random.range(0, 2 * Math.PI), Random.range(0, 2 * Math.PI)],
Random.rangeFloor(2, 10),
Random.pick(fun)
)
);
},
render({ context, width, height, playhead, deltaTime }) {
const angle = mapRange(playhead, 0, 1, 0, Math.PI * 2);
context.fillStyle = '#fff';
context.clearRect(0, 0, width, height);
context.fillRect(0, 0, width, height);
curves.forEach((curve) => {
curve.update(angle);
curve.drawEmoji(context, width * 0.0625);
});
},
};
};
canvasSketch(sketch, settings);
class Lissajous {
constructor(
center,
r,
vel = [1, 3],
start = [-Math.PI / 2, -Math.PI / 2],
length = 50,
emoji
) {
this.center = center;
this.r = r;
this.vel = vel;
this.start = start;
this.length = length;
this.emoji = emoji;
this.path = [];
}
update(angle) {
this.path = linspace(this.length).map((dt) => [
this.center[0] +
this.r * Math.cos((angle + 0.2 * dt) * this.vel[0] - this.start[0]),
this.center[1] +
this.r * Math.sin((angle + 0.2 * dt) * this.vel[1] - this.start[1]),
]);
}
drawEmoji(context, s = 32) {
context.font = `${s}px serif`;
this.path.forEach(([x, y]) => {
context.fillText(this.emoji, x, y);
});
}
}