-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathKinegram.js
108 lines (92 loc) · 3.36 KB
/
Kinegram.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
class Kinegram {
constructor(frames = [], slitWidth = 5, name = "Kinegram " + int(random(100, 999))) {
this.name = name;
this.frames = frames;
this.slitWidth = slitWidth;
this.kinegram = null;
this.overlay = null;
if (this.frames.length > 0) {
console.log("hmmmm");
this.kinegram = createImage(this.frames[0].width, this.frames[0].height);
this.overlay = createImage(this.frames[0].width * 2, this.frames[0].height);
}
}
addFrame(img) {
this.frames.push(img);
// create an blank image only when the first frame is pushed
if (this.frames.length == 1) {
this.kinegram = createImage(this.frames[0].width, this.frames[0].height);
this.overlay = createImage(this.frames[0].width * 2, this.frames[0].height);
}
}
reset() {
this.frames = [];
}
generateKinegram() {
print('generating kinegram for ' + this.name);
for (let i = 0; i < this.frames.length; i++) {
this.frames[i].loadPixels();
if (this.frames[0].width != this.frames[i].width && this.frames[0].height == this.frames[i].height) {
print("image dimensions are not consistent");
return null;
}
}
this.kinegram = createImage(this.frames[0].width, this.frames[0].height);
this.kinegram.loadPixels();
for (var x = 0; x < this.kinegram.width; x++) {
for (var y = 0; y < this.kinegram.height; y++) {
let imgIndex = int(x / this.slitWidth) % this.frames.length;
this.kinegram.set(x, y, this.frames[imgIndex].get(x, y));
}
}
this.kinegram.updatePixels();
print('done generating kinegram for ' + this.name);
return this.kinegram;
}
generateOverlay() {
print('generating overlay for ' + this.name);
this.overlay.loadPixels();
for (var x = 0; x < this.overlay.width; x++) {
for (var y = 0; y < this.overlay.height; y++) {
let index = int(x / this.slitWidth) % this.frames.length;
if (index > 0) {
this.overlay.set(x, y, color(0, 255));
} else {
this.overlay.set(x, y, color(0, 0));
}
}
}
this.overlay.updatePixels();
print('done generating overlay for ' + this.name);
return this.overlay;
}
showKinegram(x = width / 2, y = height / 2) {
if (this.kinegram !== null) {
image(this.kinegram, x, y);
}
else
console.warn('kinegram not found')
}
showOverlay(x = width / 2, y = height / 2) {
if (this.overlay !== null)
image(this.overlay, x, y);
else
console.warn('overlay not found')
}
saveKinegram(filename = this.name) {
if (this.kinegram !== null)
this.kinegram.save(filename, 'png');
else
console.warn('kinegram not found')
}
saveOverlay(filename = this.name + '_overlay') {
if (this.overlay !== null)
this.overlay.save(filename, 'png');
else
console.warn('overlay not found')
}
save(filename = this.name) {
this.saveKinegram(filename);
this.saveOverlay(filename + '_overlay');
}
}