File: radius_test.c

package info (click to toggle)
s3d 0.2.2.1-7
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 5,356 kB
  • sloc: ansic: 21,128; python: 488; perl: 98; makefile: 31; sh: 29
file content (57 lines) | stat: -rw-r--r-- 1,527 bytes parent folder | download | duplicates (3)
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
// SPDX-License-Identifier: GPL-2.0-or-later
/* SPDX-FileCopyrightText: 2004-2015  Simon Wunderlich <sw@simonwunderlich.de>
 */

#include <s3d.h>
#include <stdio.h>  /*  NULL */
#include <time.h> /* nanosleep() */
static struct timespec t = {
	0, 10*1000*1000
}; /* 10 mili seconds */

#include <math.h> /* sin(), cos() */
static int item1, item2, item3;
static int i = 0;
static void mainloop(void)
{
	float f, g, h;
	f = sinf(((float)M_PI * (i % 360)) / 180.0f);
	g = cosf(((float)M_PI * (i % 360)) / 180.0f);
	h = sinf(((float)M_PI * ((3 * i) % 360)) / 180.0f);

	s3d_translate(item1, f*10, h*2, g*5);
	s3d_rotate(item1, 0, (float)(i % 360), 0);
	/* s3d_scale(item1,h+3,h+3,h+3);*/

	/* s3d_translate(item2,f*10,0, g*5);*/
	s3d_translate(item2, 0, 0, 10);
	/* s3d_rotate(item2,i%360,0,-i%360);
	 s3d_scale(item2,2*f+5,2*f+5,2*f+5);*/

	s3d_translate(item3, 0, 0, 10);
	/* s3d_rotate(item3,((8*i)%360),0,-((8*i)%360));
	 s3d_scale(item3,2*f+5,2*f+5,2*f+5);*/



	i++;
	nanosleep(&t, NULL);
}
int main(int argc, char **argv)
{
	if (!s3d_init(&argc, &argv, "radius test")) {
		item1 = s3d_import_model_file("objs/cubeyholes.3ds");
		item2 = s3d_import_model_file("objs/folder.3ds");
		s3d_select_font("vera");
		item3 = s3d_draw_string("radius test", NULL);
		s3d_link(item2, item1);
		s3d_link(item3, item2);
		s3d_flags_on(item1, S3D_OF_VISIBLE);
		s3d_flags_on(item2, S3D_OF_VISIBLE);
		s3d_flags_on(item3, S3D_OF_VISIBLE);
		s3d_mainloop(mainloop);
		/*  wait for some object to be clicked */
		s3d_quit();
	}
	return 0;
}