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
|
/* libnsfb ploygon plotter test program */
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <math.h>
#include "libnsfb.h"
#include "libnsfb_plot.h"
#include "libnsfb_event.h"
#define UNUSED(x) ((x) = (x))
int main(int argc, char **argv)
{
nsfb_t *nsfb;
nsfb_event_t event;
nsfb_bbox_t box;
uint8_t *fbptr;
int fbstride;
int sides;
int radius;
nsfb_point_t *points;
int loop;
// nsfb_plot_pen_t pen;
UNUSED(argc);
UNUSED(argv);
nsfb = nsfb_init(NSFB_FRONTEND_SDL);
if (nsfb == NULL) {
fprintf(stderr, "Unable to initialise nsfb with SDL frontend\n");
return 1;
}
if (nsfb_init_frontend(nsfb) == -1) {
fprintf(stderr, "Unable to initialise nsfb frontend\n");
return 2;
}
/* get the geometry of the whole screen */
box.x0 = box.y0 = 0;
nsfb_get_geometry(nsfb, &box.x1, &box.y1, NULL);
nsfb_get_framebuffer(nsfb, &fbptr, &fbstride);
/* claim the whole screen for update */
nsfb_claim(nsfb, &box);
nsfb_plot_clg(nsfb, 0xffffffff);
radius = (box.x1 / 3);
for (sides = 13; sides >=3; sides--) {
points = malloc(sizeof(nsfb_point_t) * sides);
for (loop = 0; loop < sides;loop++) {
points[loop].x = (box.x1 / 2) +
(radius * cos(loop * 2 * M_PI / sides));
points[loop].y = (box.y1 / 2) +
(radius * sin(loop * 2 * M_PI / sides));
}
nsfb_plot_polygon(nsfb, (const int *)points, sides,
0xff000000 | (0xffffff / (sides * 2)));
free(points);
radius -= 25;
}
nsfb_update(nsfb, &box);
while (event.type != NSFB_EVENT_CONTROL)
nsfb_event(nsfb, &event, -1);
return 0;
}
|