-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathbitfolly.js
74 lines (69 loc) · 1.95 KB
/
bitfolly.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
import { GPU } from "gpu.js/dist/gpu-browser.js";
export default class Bitfolly {
constructor(getAudioData, canvas) {
if (!canvas) {
canvas = document.createElement("canvas");
canvas.width = Math.floor(window.innerWidth);
canvas.height = Math.floor(window.innerHeight);
}
this.gpu = new GPU({canvas});
this.canvas = canvas;
this.getAudioData = getAudioData || (() => []);
this.started = false;
this.audioTime = 0;
this.previousTime = 0;
this.start();
}
callKernel(kernel) {
let width = this.canvas.width;
let height = this.canvas.height;
let audioData = this.getAudioData();
this.audioTime += audioData.reduce((a,b) => a+b, 0)/1000;
kernel(this.previousTime, this.canvas, width, height, audioData, this.audioTime);
}
update(code) {
const codeFn = Function("t", "p", "w", "h", "a", "at", `
let x = this.thread.x;
let y = this.thread.y;
let c = [-1,-1,-1,-1];
let o = -1;
${/\w\s=\s/.test(code) ? code : "o = " + code}
if (c[0] !== -1 || c[1] !== -1 || c[2] !== -1 || c[3] !== -1) {
this.color(
c[0]==-1?0:c[0]/255,
c[1]==-1?0:c[1]/255,
c[2]==-1?0:c[2]/255,
c[3]==-1?0:c[3]/255,
);
} else {
o = o==-1?0:o/255;
this.color(o, o, o, 1);
}
`);
let width = this.canvas.width;
let height = this.canvas.height;
let kernel = this.gpu.createKernel(codeFn)
.setOutput([width, height])
.setGraphical(true);
// Call it to catch errors early
this.callKernel(kernel);
this.kernel = kernel;
}
render(time) {
this.previousTime = time;
if (this.kernel) {
try {
this.callKernel(this.kernel);
} catch (err) {
console.error(err);
}
}
requestAnimationFrame(this.render.bind(this))
}
start() {
if (!this.started) {
this.started = true;
requestAnimationFrame(this.render.bind(this));
}
}
}