summaryrefslogtreecommitdiff
path: root/test/polystar.c
blob: 98974584d9e1f249d86e1a33b5e61b30c649a5a5 (plain)
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
/* 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);

    pen.stroke_colour = 0xff000000;
    pen.stroke_type = NFSB_PLOT_OPTYPE_SOLID;

    nsfb_plot_clg(nsfb, 0xffffffff);

    radius = (box.y1 / 2);

    for (sides = 14; sides >=6; sides-=2) {
	    points = malloc(sizeof(nsfb_point_t) * sides);

	    for (loop = 0; loop < sides;loop+=2) {
		    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));

		    points[loop+1].x = (box.x1 / 2) + 
			    ((radius / 3) * cos((loop+1) * 2 * M_PI / sides));
		    points[loop+1].y = (box.y1 / 2) + 
			    ((radius / 3) * sin((loop+1) * 2 * M_PI / sides));
	    }

	    nsfb_plot_polygon(nsfb, (const int *)points, sides, 
			      0xff000000 | (0xffffff / (sides * 2)));

	    nsfb_plot_polylines(nsfb, sides, points, &pen);

	    free(points);
	    radius -= 40;
    }

    nsfb_update(nsfb, &box);
    
    while (event.type != NSFB_EVENT_CONTROL)
        nsfb_event(nsfb, &event, -1);

    return 0;
}