-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathexperimental.ino
89 lines (65 loc) · 2.33 KB
/
experimental.ino
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
// some stuff which has to prove if its worth to become part of FunkyNoise
// a try to output a variable onto the SmartMatrix
void PrintValue() {
pSmartMatrix->swapBuffers(true);
char value[3];
value[0] = '0' + brightness / 100;
value[1] = '0' + (brightness % 100) / 10;
value[2] = '0' + brightness % 10;
pSmartMatrix->drawString(0, 16, {
200, 200, 200 }
, value);
pSmartMatrix->swapBuffers(true);
delay(500);
}
// All the caleidoscope functions work directly within the screenbuffer (leds array).
// Draw whatever you like in the area x(0-15) and y (0-15) and then copy it arround.
// rotates the first 16x16 quadrant 3 times onto a 32x32 (+90 degrees rotation for each one)
void Caleidoscope1() {
for(int x = 0; x < kMatrixWidth / 2 ; x++) {
for(int y = 0; y < kMatrixHeight / 2; y++) {
leds[XY( kMatrixWidth - 1 - x, y )] = leds[XY( y, x )];
leds[XY( kMatrixWidth - 1 - x, kMatrixHeight - 1 - y )] = leds[XY( x, y )];
leds[XY( x, kMatrixHeight - 1 - y )] = leds[XY( y, x )];
}
}
}
// mirror the first 16x16 quadrant 3 times onto a 32x32
void Caleidoscope2() {
for(int x = 0; x < kMatrixWidth / 2 ; x++) {
for(int y = 0; y < kMatrixHeight / 2; y++) {
leds[XY( kMatrixWidth - 1 - x, y )] = leds[XY( x, y )];
leds[XY( x, kMatrixHeight - 1 - y )] = leds[XY( x, y )];
leds[XY( kMatrixWidth - 1 - x, kMatrixHeight - 1 - y )] = leds[XY( x, y )];
}
}
}
// copy one diagonal triangle into the other one within a 16x16
void Caleidoscope3() {
for(int x = 0; x <= CentreX ; x++) {
for(int y = 0; y <= x; y++) {
leds[XY( x, y )] = leds[XY( y, x )];
}
}
}
// copy one diagonal triangle into the other one within a 16x16 (90 degrees rotated compared to Caleidoscope3)
void Caleidoscope4() {
for(int x = 0; x <= CentreX ; x++) {
for(int y = 0; y <= CentreY-x; y++) {
leds[XY( CentreY - y, CentreX - x )] = leds[XY( x, y )];
}
}
}
// copy one diagonal triangle into the other one within a 8x8
void Caleidoscope5() {
for(int x = 0; x < kMatrixWidth/4 ; x++) {
for(int y = 0; y <= x; y++) {
leds[XY( x, y )] = leds[XY( y, x )];
}
}
for(int x = kMatrixWidth/4; x < kMatrixWidth/2 ; x++) {
for(int y = kMatrixHeight/4; y >= 0; y--) {
leds[XY( x, y )] = leds[XY( y, x )];
}
}
}