annotate ppe/chara_state25.cc @ 67:21ac9f57a6d4

Mac OS X 64bit
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 21 May 2011 16:27:41 +0900
parents 6626e451a09d
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
34
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #include "task_base.h"
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 #include "task_object.h"
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 #include "Sankaku.h"
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
4
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 SchedDefineTask1(State25, state25);
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
6
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 static int
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 state25(SchedTask *smanager, void *rbuf, void *wbuf)
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 {
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 int length = 1;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 int amari;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
12
67
21ac9f57a6d4 Mac OS X 64bit
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 38
diff changeset
13 long part1_f = (long)smanager->get_param(0);
21ac9f57a6d4 Mac OS X 64bit
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 38
diff changeset
14 long part5_f = (long)smanager->get_param(1);
21ac9f57a6d4 Mac OS X 64bit
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 38
diff changeset
15 long rand = (long)smanager->get_param(2);
34
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
16
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0);
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 int count = *(int*)smanager->get_input(rbuf, 1);
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
19
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 smanager->set_outputSize(4, sizeof(ObjContainer)+sizeof(ObjData)*(length-1));
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 smanager->setup_outputData();
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
22
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 CHARACTER *q = (CHARACTER*)smanager->get_output(wbuf, 0);
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 int *w_count = (int*)smanager->get_output(wbuf, 1);
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 int *rinkx = (int*)smanager->get_output(wbuf, 2);
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 int *rinkf1 = (int*)smanager->get_output(wbuf, 3);
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 ObjContainerPtr sprite = (ObjContainerPtr)smanager->get_output(wbuf, 4);
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 sprite->flag = true;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 sprite->length = length;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
30
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 if(p->dt1 <= 360)
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 {
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 p->x = Mycos(p->dt1) * 30 / SANKAKU + 82 + 32;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 p->y = Mysin(p->dt1) * 30 / SANKAKU + 30;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 }
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 if(p->dt1 > 360)
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 {
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 p->x = Mycos(p->dt1) * 30 * -1 /SANKAKU + 142 + 32;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 p->y = Mysin(p->dt1) * 30 / SANKAKU + 30;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 }
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 count++;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 *w_count = count;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 PutSprite(count, p->x - 42, p->y, 64, &sprite->data[0]);
38
6626e451a09d fix random number.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
44 amari = rand % 160;
34
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 if((amari == 1) && (part5_f == TRUE))
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 {
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 p->task = STATE26;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 *rinkf1 = 1;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 }
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 if((amari == 2) && (part1_f == TRUE))
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 {
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 p->task = STATE27;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 *rinkf1 = 5;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 *rinkx = 0;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
55
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 *q = *p;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 return 0;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 }
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 if((part5_f == TRUE) && (part1_f != TRUE))
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 {
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 p->task = STATE28;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 }
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 p->dt1 += 3;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 if(p->dt1 == 720)
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 {
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 p->dt1 = 0;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 }
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
68
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 *q = *p;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 return 0;
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 }