annotate programs/walk.cc @ 3:e717e593f213

add walk-example
author e075725
date Wed, 09 Dec 2009 17:29:35 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3
e717e593f213 add walk-example
e075725
parents:
diff changeset
1 #include <math.h>
e717e593f213 add walk-example
e075725
parents:
diff changeset
2 #include <stdlib.h>
e717e593f213 add walk-example
e075725
parents:
diff changeset
3 #include "SceneGraphRoot.h"
e717e593f213 add walk-example
e075725
parents:
diff changeset
4 #include "MainLoop.h"
e717e593f213 add walk-example
e075725
parents:
diff changeset
5 #include "walk.h"
e717e593f213 add walk-example
e075725
parents:
diff changeset
6
e717e593f213 add walk-example
e075725
parents:
diff changeset
7 // prototype
e717e593f213 add walk-example
e075725
parents:
diff changeset
8 static void arm_move(SceneGraphPtr node, void *sgroot_, int screen_w, int screen_h);
e717e593f213 add walk-example
e075725
parents:
diff changeset
9 static void ball_move(SceneGraphPtr node, void *sgroot_, int screen_w, int screen_h);
e717e593f213 add walk-example
e075725
parents:
diff changeset
10 static void ball_collision(SceneGraphPtr node, void *sgroot_, int screen_w, int screen_h, SceneGraphPtr tree);
e717e593f213 add walk-example
e075725
parents:
diff changeset
11 static void ball_collision_idle(SceneGraphPtr, void *sgroot_, int w, int h, SceneGraphPtr tree);
e717e593f213 add walk-example
e075725
parents:
diff changeset
12
e717e593f213 add walk-example
e075725
parents:
diff changeset
13 static float vy = 0.0f; // y 方向速度
e717e593f213 add walk-example
e075725
parents:
diff changeset
14 static float dt = 1.0/1.0f; // frame rate
e717e593f213 add walk-example
e075725
parents:
diff changeset
15
e717e593f213 add walk-example
e075725
parents:
diff changeset
16 static float e = -0.8f; // 反発係数
e717e593f213 add walk-example
e075725
parents:
diff changeset
17 static float g = 9.8f; // 重力加速度
e717e593f213 add walk-example
e075725
parents:
diff changeset
18 //static float v0 = 0.0f; // 初速は 0
e717e593f213 add walk-example
e075725
parents:
diff changeset
19
e717e593f213 add walk-example
e075725
parents:
diff changeset
20 static float h0; // 初期高さ
e717e593f213 add walk-example
e075725
parents:
diff changeset
21 static float ball_radius = 100.0f;
e717e593f213 add walk-example
e075725
parents:
diff changeset
22
e717e593f213 add walk-example
e075725
parents:
diff changeset
23 static float speed = 10.0f;
e717e593f213 add walk-example
e075725
parents:
diff changeset
24
e717e593f213 add walk-example
e075725
parents:
diff changeset
25 static void
e717e593f213 add walk-example
e075725
parents:
diff changeset
26 ball_move_idle2(SceneGraphPtr node, void *sgroot_, int screen_w, int screen_h)
e717e593f213 add walk-example
e075725
parents:
diff changeset
27 {
e717e593f213 add walk-example
e075725
parents:
diff changeset
28 SceneGraphRoot *sgroot = (SceneGraphRoot *)sgroot_;
e717e593f213 add walk-example
e075725
parents:
diff changeset
29 Pad *pad = sgroot->getController();
e717e593f213 add walk-example
e075725
parents:
diff changeset
30
e717e593f213 add walk-example
e075725
parents:
diff changeset
31 if (pad->circle.isHold()) {
e717e593f213 add walk-example
e075725
parents:
diff changeset
32 if (pad->left.isHold()) {
e717e593f213 add walk-example
e075725
parents:
diff changeset
33 node->xyz[0] -= speed;
e717e593f213 add walk-example
e075725
parents:
diff changeset
34 if(node->xyz[0] < ball_radius)
e717e593f213 add walk-example
e075725
parents:
diff changeset
35 node->xyz[0] = ball_radius;
e717e593f213 add walk-example
e075725
parents:
diff changeset
36 } else if (pad->right.isHold()) {
e717e593f213 add walk-example
e075725
parents:
diff changeset
37 node->xyz[0] += speed;
e717e593f213 add walk-example
e075725
parents:
diff changeset
38 if(node->xyz[0] > screen_w - ball_radius)
e717e593f213 add walk-example
e075725
parents:
diff changeset
39 node->xyz[0] = screen_w - ball_radius;
e717e593f213 add walk-example
e075725
parents:
diff changeset
40 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
41
e717e593f213 add walk-example
e075725
parents:
diff changeset
42 if (pad->up.isHold()) {
e717e593f213 add walk-example
e075725
parents:
diff changeset
43 node->xyz[1] -= speed;
e717e593f213 add walk-example
e075725
parents:
diff changeset
44 } else if (pad->down.isHold()) {
e717e593f213 add walk-example
e075725
parents:
diff changeset
45 node->xyz[1] += speed;
e717e593f213 add walk-example
e075725
parents:
diff changeset
46 if(node->xyz[1] > screen_h - ball_radius)
e717e593f213 add walk-example
e075725
parents:
diff changeset
47 node->xyz[1] = screen_h - ball_radius;
e717e593f213 add walk-example
e075725
parents:
diff changeset
48 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
49 } else {
e717e593f213 add walk-example
e075725
parents:
diff changeset
50 node->set_move_collision(ball_move, ball_collision);
e717e593f213 add walk-example
e075725
parents:
diff changeset
51 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
52 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
53
e717e593f213 add walk-example
e075725
parents:
diff changeset
54 static int time = 0;
e717e593f213 add walk-example
e075725
parents:
diff changeset
55
e717e593f213 add walk-example
e075725
parents:
diff changeset
56 static void
e717e593f213 add walk-example
e075725
parents:
diff changeset
57 ball_move_idle(SceneGraphPtr node, void *sgroot_, int screen_w, int screen_h)
e717e593f213 add walk-example
e075725
parents:
diff changeset
58 {
e717e593f213 add walk-example
e075725
parents:
diff changeset
59 SceneGraphRoot *sgroot = (SceneGraphRoot *)sgroot_;
e717e593f213 add walk-example
e075725
parents:
diff changeset
60 Pad *pad = sgroot->getController();
e717e593f213 add walk-example
e075725
parents:
diff changeset
61
e717e593f213 add walk-example
e075725
parents:
diff changeset
62 if (pad->circle.isPush()) {
e717e593f213 add walk-example
e075725
parents:
diff changeset
63 node->set_move_collision(ball_move_idle2, ball_collision_idle);
e717e593f213 add walk-example
e075725
parents:
diff changeset
64 time = 0;
e717e593f213 add walk-example
e075725
parents:
diff changeset
65 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
66
e717e593f213 add walk-example
e075725
parents:
diff changeset
67 time++;
e717e593f213 add walk-example
e075725
parents:
diff changeset
68
e717e593f213 add walk-example
e075725
parents:
diff changeset
69 if (time > 90) {
e717e593f213 add walk-example
e075725
parents:
diff changeset
70 float w = (float)random();
e717e593f213 add walk-example
e075725
parents:
diff changeset
71
e717e593f213 add walk-example
e075725
parents:
diff changeset
72 w = fmodf(w, screen_w - ball_radius*2);
e717e593f213 add walk-example
e075725
parents:
diff changeset
73 node->xyz[0] = w + ball_radius;
e717e593f213 add walk-example
e075725
parents:
diff changeset
74 node->xyz[1] = h0;
e717e593f213 add walk-example
e075725
parents:
diff changeset
75 node->set_move_collision(ball_move, ball_collision);
e717e593f213 add walk-example
e075725
parents:
diff changeset
76 time = 0;
e717e593f213 add walk-example
e075725
parents:
diff changeset
77 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
78 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
79
e717e593f213 add walk-example
e075725
parents:
diff changeset
80 static void
e717e593f213 add walk-example
e075725
parents:
diff changeset
81 ball_move(SceneGraphPtr node, void *sgroot_, int screen_w, int screen_h)
e717e593f213 add walk-example
e075725
parents:
diff changeset
82 {
e717e593f213 add walk-example
e075725
parents:
diff changeset
83 vy += g * dt;
e717e593f213 add walk-example
e075725
parents:
diff changeset
84 node->xyz[1] += vy * dt;
e717e593f213 add walk-example
e075725
parents:
diff changeset
85 // node->xyz[0] += 10.0f;
e717e593f213 add walk-example
e075725
parents:
diff changeset
86 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
87
e717e593f213 add walk-example
e075725
parents:
diff changeset
88 static void
e717e593f213 add walk-example
e075725
parents:
diff changeset
89 ball_collision_idle(SceneGraphPtr, void *sgroot_, int w, int h, SceneGraphPtr tree)
e717e593f213 add walk-example
e075725
parents:
diff changeset
90 {
e717e593f213 add walk-example
e075725
parents:
diff changeset
91 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
92
e717e593f213 add walk-example
e075725
parents:
diff changeset
93 static void
e717e593f213 add walk-example
e075725
parents:
diff changeset
94 ball_collision(SceneGraphPtr node, void *sgroot_, int screen_w, int screen_h,
e717e593f213 add walk-example
e075725
parents:
diff changeset
95 SceneGraphPtr tree)
e717e593f213 add walk-example
e075725
parents:
diff changeset
96 {
e717e593f213 add walk-example
e075725
parents:
diff changeset
97 if (node->xyz[1] > screen_h - ball_radius) {
e717e593f213 add walk-example
e075725
parents:
diff changeset
98 node->xyz[1] = screen_h - ball_radius;
e717e593f213 add walk-example
e075725
parents:
diff changeset
99
e717e593f213 add walk-example
e075725
parents:
diff changeset
100 vy *= e;
e717e593f213 add walk-example
e075725
parents:
diff changeset
101 if (vy > -g && vy < 0) {
e717e593f213 add walk-example
e075725
parents:
diff changeset
102 vy = 0.0;
e717e593f213 add walk-example
e075725
parents:
diff changeset
103 node->set_move_collision(ball_move_idle, ball_collision_idle);
e717e593f213 add walk-example
e075725
parents:
diff changeset
104 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
105 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
106 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
107
e717e593f213 add walk-example
e075725
parents:
diff changeset
108 MainLoopPtr
e717e593f213 add walk-example
e075725
parents:
diff changeset
109 walk::init(Viewer *sgroot, int screen_w, int screen_h)
e717e593f213 add walk-example
e075725
parents:
diff changeset
110 {
e717e593f213 add walk-example
e075725
parents:
diff changeset
111 SceneGraphPtr root, body, head, r_leg_1, l_leg_1, r_leg_2, l_leg_2, r_arm_1, l_arm_1, r_arm_2, l_arm_2;
e717e593f213 add walk-example
e075725
parents:
diff changeset
112
e717e593f213 add walk-example
e075725
parents:
diff changeset
113 // 固定した値で srandom すると、毎回同じ、random() 列が生成される
e717e593f213 add walk-example
e075725
parents:
diff changeset
114 // random な値が欲しいなら、man random に方法が書いてあります。
e717e593f213 add walk-example
e075725
parents:
diff changeset
115 srandom(100);
e717e593f213 add walk-example
e075725
parents:
diff changeset
116
e717e593f213 add walk-example
e075725
parents:
diff changeset
117 sgroot->createFromXMLfile("xml_file/tetsujin_3.xml");
e717e593f213 add walk-example
e075725
parents:
diff changeset
118
e717e593f213 add walk-example
e075725
parents:
diff changeset
119 root = sgroot->createSceneGraph();
e717e593f213 add walk-example
e075725
parents:
diff changeset
120 body = sgroot->createSceneGraph("body");
e717e593f213 add walk-example
e075725
parents:
diff changeset
121 //body->set_move_collision(ball_move, ball_collision);
e717e593f213 add walk-example
e075725
parents:
diff changeset
122
e717e593f213 add walk-example
e075725
parents:
diff changeset
123 head = sgroot->createSceneGraph("head");
e717e593f213 add walk-example
e075725
parents:
diff changeset
124 r_leg_1 = sgroot->createSceneGraph("right_leg_1");
e717e593f213 add walk-example
e075725
parents:
diff changeset
125 l_leg_1 = sgroot->createSceneGraph("left_leg_1");
e717e593f213 add walk-example
e075725
parents:
diff changeset
126 r_leg_2 = sgroot->createSceneGraph("right_leg_2");
e717e593f213 add walk-example
e075725
parents:
diff changeset
127 l_leg_2 = sgroot->createSceneGraph("left_leg_2");
e717e593f213 add walk-example
e075725
parents:
diff changeset
128 r_arm_1 = sgroot->createSceneGraph("right_arm_1");
e717e593f213 add walk-example
e075725
parents:
diff changeset
129 l_arm_1 = sgroot->createSceneGraph("left_arm_1");
e717e593f213 add walk-example
e075725
parents:
diff changeset
130 r_arm_2 = sgroot->createSceneGraph("right_arm_2");
e717e593f213 add walk-example
e075725
parents:
diff changeset
131 l_arm_2 = sgroot->createSceneGraph("left_arm_2");
e717e593f213 add walk-example
e075725
parents:
diff changeset
132
e717e593f213 add walk-example
e075725
parents:
diff changeset
133 root->addChild(body);
e717e593f213 add walk-example
e075725
parents:
diff changeset
134 body->addChild(head);
e717e593f213 add walk-example
e075725
parents:
diff changeset
135 r_leg_2->addChild(r_leg_1);
e717e593f213 add walk-example
e075725
parents:
diff changeset
136 l_leg_2->addChild(l_leg_1);
e717e593f213 add walk-example
e075725
parents:
diff changeset
137 body->addChild(r_leg_2);
e717e593f213 add walk-example
e075725
parents:
diff changeset
138 body->addChild(l_leg_2);
e717e593f213 add walk-example
e075725
parents:
diff changeset
139 r_arm_2->addChild(r_arm_1);
e717e593f213 add walk-example
e075725
parents:
diff changeset
140 l_arm_2->addChild(l_arm_1);
e717e593f213 add walk-example
e075725
parents:
diff changeset
141 body->addChild(r_arm_2);
e717e593f213 add walk-example
e075725
parents:
diff changeset
142 body->addChild(l_arm_2);
e717e593f213 add walk-example
e075725
parents:
diff changeset
143
e717e593f213 add walk-example
e075725
parents:
diff changeset
144 //h0 = screen_h/2;
e717e593f213 add walk-example
e075725
parents:
diff changeset
145 //h0 = -1000;
e717e593f213 add walk-example
e075725
parents:
diff changeset
146
e717e593f213 add walk-example
e075725
parents:
diff changeset
147 body->xyz[0] = screen_w/2;
e717e593f213 add walk-example
e075725
parents:
diff changeset
148 //ball->xyz[0] = 0.0f;
e717e593f213 add walk-example
e075725
parents:
diff changeset
149 body->xyz[1] = screen_h/2 + 25;
e717e593f213 add walk-example
e075725
parents:
diff changeset
150 body->xyz[2] = 0.0f;
e717e593f213 add walk-example
e075725
parents:
diff changeset
151 body->angle[0] = -90.0f;
e717e593f213 add walk-example
e075725
parents:
diff changeset
152
e717e593f213 add walk-example
e075725
parents:
diff changeset
153 r_arm_1->angle[1] = -45.0f;
e717e593f213 add walk-example
e075725
parents:
diff changeset
154 r_arm_1->xyz[0] = 0;
e717e593f213 add walk-example
e075725
parents:
diff changeset
155 r_arm_1->xyz[1] = 0;
e717e593f213 add walk-example
e075725
parents:
diff changeset
156 r_arm_1->xyz[2] = 0;
e717e593f213 add walk-example
e075725
parents:
diff changeset
157
e717e593f213 add walk-example
e075725
parents:
diff changeset
158 sgroot->setSceneData(root);
e717e593f213 add walk-example
e075725
parents:
diff changeset
159
e717e593f213 add walk-example
e075725
parents:
diff changeset
160 return sgroot;
e717e593f213 add walk-example
e075725
parents:
diff changeset
161 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
162
e717e593f213 add walk-example
e075725
parents:
diff changeset
163 MainLoopPtr
e717e593f213 add walk-example
e075725
parents:
diff changeset
164 walk::init_only_sg(SgChange *sgroot, int screen_w, int screen_h)
e717e593f213 add walk-example
e075725
parents:
diff changeset
165 {
e717e593f213 add walk-example
e075725
parents:
diff changeset
166 return sgroot;
e717e593f213 add walk-example
e075725
parents:
diff changeset
167 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
168
e717e593f213 add walk-example
e075725
parents:
diff changeset
169 extern Application *
e717e593f213 add walk-example
e075725
parents:
diff changeset
170 application() {
e717e593f213 add walk-example
e075725
parents:
diff changeset
171 return new walk();
e717e593f213 add walk-example
e075725
parents:
diff changeset
172 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
173
e717e593f213 add walk-example
e075725
parents:
diff changeset
174 const char *usr_help_str = "Usage: ./test_nogl [OPTION]\n";
e717e593f213 add walk-example
e075725
parents:
diff changeset
175
e717e593f213 add walk-example
e075725
parents:
diff changeset
176 extern int init(TaskManager *manager, int argc, char *argv[]);
e717e593f213 add walk-example
e075725
parents:
diff changeset
177 extern void task_initialize();
e717e593f213 add walk-example
e075725
parents:
diff changeset
178 static void TMend(TaskManager *manager);
e717e593f213 add walk-example
e075725
parents:
diff changeset
179
e717e593f213 add walk-example
e075725
parents:
diff changeset
180 int
e717e593f213 add walk-example
e075725
parents:
diff changeset
181 TMmain(TaskManager *manager, int argc, char *argv[])
e717e593f213 add walk-example
e075725
parents:
diff changeset
182 {
e717e593f213 add walk-example
e075725
parents:
diff changeset
183 task_initialize();
e717e593f213 add walk-example
e075725
parents:
diff changeset
184 manager->set_TMend(TMend);
e717e593f213 add walk-example
e075725
parents:
diff changeset
185 return init(manager, argc, argv);
e717e593f213 add walk-example
e075725
parents:
diff changeset
186
e717e593f213 add walk-example
e075725
parents:
diff changeset
187 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
188
e717e593f213 add walk-example
e075725
parents:
diff changeset
189 void
e717e593f213 add walk-example
e075725
parents:
diff changeset
190 TMend(TaskManager *manager)
e717e593f213 add walk-example
e075725
parents:
diff changeset
191 {
e717e593f213 add walk-example
e075725
parents:
diff changeset
192 printf("test_nogl end\n");
e717e593f213 add walk-example
e075725
parents:
diff changeset
193 }
e717e593f213 add walk-example
e075725
parents:
diff changeset
194
e717e593f213 add walk-example
e075725
parents:
diff changeset
195 /* end */