34
|
1 #include "task_base.h"
|
|
2 #include "task_object.h"
|
|
3 #include "Sankaku.h"
|
|
4
|
|
5 SchedDefineTask1(State25, state25);
|
|
6
|
|
7 static int
|
|
8 state25(SchedTask *smanager, void *rbuf, void *wbuf)
|
|
9 {
|
|
10 int length = 1;
|
|
11 int amari;
|
|
12
|
67
|
13 long part1_f = (long)smanager->get_param(0);
|
|
14 long part5_f = (long)smanager->get_param(1);
|
|
15 long rand = (long)smanager->get_param(2);
|
34
|
16
|
|
17 CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0);
|
|
18 int count = *(int*)smanager->get_input(rbuf, 1);
|
|
19
|
|
20 smanager->set_outputSize(4, sizeof(ObjContainer)+sizeof(ObjData)*(length-1));
|
|
21 smanager->setup_outputData();
|
|
22
|
|
23 CHARACTER *q = (CHARACTER*)smanager->get_output(wbuf, 0);
|
|
24 int *w_count = (int*)smanager->get_output(wbuf, 1);
|
|
25 int *rinkx = (int*)smanager->get_output(wbuf, 2);
|
|
26 int *rinkf1 = (int*)smanager->get_output(wbuf, 3);
|
|
27 ObjContainerPtr sprite = (ObjContainerPtr)smanager->get_output(wbuf, 4);
|
|
28 sprite->flag = true;
|
|
29 sprite->length = length;
|
|
30
|
|
31 if(p->dt1 <= 360)
|
|
32 {
|
|
33 p->x = Mycos(p->dt1) * 30 / SANKAKU + 82 + 32;
|
|
34 p->y = Mysin(p->dt1) * 30 / SANKAKU + 30;
|
|
35 }
|
|
36 if(p->dt1 > 360)
|
|
37 {
|
|
38 p->x = Mycos(p->dt1) * 30 * -1 /SANKAKU + 142 + 32;
|
|
39 p->y = Mysin(p->dt1) * 30 / SANKAKU + 30;
|
|
40 }
|
|
41 count++;
|
|
42 *w_count = count;
|
|
43 PutSprite(count, p->x - 42, p->y, 64, &sprite->data[0]);
|
38
|
44 amari = rand % 160;
|
34
|
45 if((amari == 1) && (part5_f == TRUE))
|
|
46 {
|
|
47 p->task = STATE26;
|
|
48 *rinkf1 = 1;
|
|
49 }
|
|
50 if((amari == 2) && (part1_f == TRUE))
|
|
51 {
|
|
52 p->task = STATE27;
|
|
53 *rinkf1 = 5;
|
|
54 *rinkx = 0;
|
|
55
|
|
56 *q = *p;
|
|
57 return 0;
|
|
58 }
|
|
59 if((part5_f == TRUE) && (part1_f != TRUE))
|
|
60 {
|
|
61 p->task = STATE28;
|
|
62 }
|
|
63 p->dt1 += 3;
|
|
64 if(p->dt1 == 720)
|
|
65 {
|
|
66 p->dt1 = 0;
|
|
67 }
|
|
68
|
|
69 *q = *p;
|
|
70 return 0;
|
|
71 }
|