-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathsine.c
75 lines (63 loc) · 1.44 KB
/
sine.c
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
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define PI 3.14159265358
unsigned char leds, revs, speed, totalframes;
struct pixel {
unsigned char r;
unsigned char g;
unsigned char b;
};
struct pixel *getPixel(struct pixel *frames, int i, int j, int k){
unsigned addr = i + j * leds + k * leds * revs;
return frames + addr;
}
int main(){
leds = 60;
revs = 120;
speed = 1;
int sinx;
int amplitude = leds/2-1;
totalframes = amplitude * 2;
FILE *fp;
struct pixel *frames, *p;
fp = fopen("sine.led","w");
fprintf(fp, "%c%c%c%c%c%c%c%c", leds, revs, speed, totalframes, 0x00,0x00,0x00,0x00);
unsigned long size = leds * revs * totalframes * sizeof(struct pixel);
frames = malloc(size);
memset(frames, 0x00, size);
int amp = amplitude;
int dir = -2;
int i,j;
for (j = 0; j < totalframes; ++j){
for (i = 0; i < revs; ++i){
int sinx = (int)(.5+leds/2 + amp * (sin(PI * i * 2.0 / (revs / 2.0))));
int k,l;
for (k = 0; k < sinx; ++k){
p = getPixel(frames, k, i, j);
p->r = 0x00;
p->g = 0xcc;
p->b = 0x99;
}
for (l = sinx; l < leds; ++l){
p = getPixel(frames, l, i, j);
p->r = 0xff;
p->g = 0x33;
p->b = 0x66;
}
p = getPixel(frames, sinx, i, j);
p->r = 0xff;
p->g = 0xff;
p->b = 0xff;
}
if (amp == amplitude){
dir = -2;
}else if (amp == -1 * amplitude){
dir = 2;
}
amp = amp + dir;
}
fwrite(frames, sizeof(char), size, fp);
fclose(fp);
}