annotate Renderer/test_render/ball_bound.cpp @ 503:516d5c91d5b4 draft double-linked-task-list

comment
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sun, 11 Oct 2009 19:35:33 +0900
parents 15bfacccde99
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
283
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
1 #include <math.h>
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
2 #include <stdlib.h>
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
3 #include "SceneGraphRoot.h"
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
4 #include "SGList.h"
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
5
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
6 // prototype
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
7 static void ball_move(SceneGraphPtr node, int screen_w, int screen_h);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
8 static void ball_collision(SceneGraphPtr node, int screen_w, int screen_h, SceneGraphPtr tree);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
9 static void ball_collision_idle(SceneGraphPtr, int w, int h, SceneGraphPtr tree);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
10
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
11
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
12 static float vy = 0.0f; // y 方向速度
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
13 static float dt = 1.0/1.0f; // frame rate
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
14
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
15 static float e = -0.8f; // 反発係数
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
16 static float g = 9.8f; // 重力加速度
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
17 //static float v0 = 0.0f; // 初速は 0
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
18
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
19 static float h0; // 初期高さ
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
20 static float ball_radius = 100.0f;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
21
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
22 static int speed = 10.0f;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
23
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
24 static void
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
25 ball_move_idle2(SceneGraphPtr node, int screen_w, int screen_h)
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
26 {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
27 Pad *pad = sgroot->getController();
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
28
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
29 if (pad->circle.isHold()) {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
30 if (pad->left.isHold()) {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
31 node->xyz[0] -= speed;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
32 if(node->xyz[0] < ball_radius)
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
33 node->xyz[0] = ball_radius;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
34 } else if (pad->right.isHold()) {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
35 node->xyz[0] += speed;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
36 if(node->xyz[0] > screen_w - ball_radius)
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
37 node->xyz[0] = screen_w - ball_radius;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
38 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
39
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
40 if (pad->up.isHold()) {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
41 node->xyz[1] -= speed;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
42 } else if (pad->down.isHold()) {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
43 node->xyz[1] += speed;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
44 if(node->xyz[1] > screen_h - ball_radius)
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
45 node->xyz[1] = screen_h - ball_radius;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
46 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
47 } else {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
48 node->set_move_collision(ball_move, ball_collision);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
49 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
50 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
51
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
52 static int time = 0;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
53
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
54 static void
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
55 ball_move_idle(SceneGraphPtr node, int screen_w, int screen_h)
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
56 {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
57 Pad *pad = sgroot->getController();
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
58
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
59 if (pad->circle.isPush()) {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
60 node->set_move_collision(ball_move_idle2, ball_collision_idle);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
61 time = 0;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
62 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
63
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
64 time++;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
65
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
66 if (time > 90) {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
67 float w = (float)random();
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
68
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
69 w = fmodf(w, screen_w - ball_radius*2);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
70 node->xyz[0] = w + ball_radius;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
71 node->xyz[1] = h0;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
72 node->set_move_collision(ball_move, ball_collision);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
73 time = 0;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
74 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
75 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
76
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
77 static void
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
78 ball_move(SceneGraphPtr node, int screen_w, int screen_h)
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
79 {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
80 vy += g * dt;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
81 node->xyz[1] += vy * dt;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
82 // node->xyz[0] += 10.0f;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
83 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
84
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
85 static void
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
86 ball_collision_idle(SceneGraphPtr, int w, int h, SceneGraphPtr tree)
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
87 {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
88 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
89
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
90 static void
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
91 ball_collision(SceneGraphPtr node, int screen_w, int screen_h,
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
92 SceneGraphPtr tree)
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
93 {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
94 if (node->xyz[1] > screen_h - ball_radius) {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
95 node->xyz[1] = screen_h - ball_radius;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
96
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
97 vy *= e;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
98 if (vy > -g && vy < 0) {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
99 vy = 0.0;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
100 node->set_move_collision(ball_move_idle, ball_collision_idle);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
101 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
102 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
103 }
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
104
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
105
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
106 void
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
107 ball_bound_init(int screen_w, int screen_h)
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
108 {
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
109 SceneGraphPtr ball;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
110
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
111 srandom(100);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
112
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
113 sgroot->createFromXMLfile("xml_file/Ball.xml");
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
114 ball = sgroot->createSceneGraph(Ball);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
115 ball->set_move_collision(ball_move, ball_collision);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
116
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
117 h0 = screen_h/2;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
118 h0 = -1000;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
119
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
120 ball->xyz[0] = screen_w/2;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
121 //ball->xyz[0] = 0.0f;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
122 ball->xyz[1] = h0;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
123 ball->xyz[2] = 30.0f;
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
124
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
125 sgroot->setSceneData(ball);
15bfacccde99 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
126 }