Mercurial > hg > Members > koba > t_dandy
diff spe/chara_state28.cc @ 49:f4140672ef9f
fix.
author | koba <koba@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Fri, 21 Jan 2011 22:18:28 +0900 |
parents | c330ded6d728 |
children | cfd42ee2ad28 |
line wrap: on
line diff
--- a/spe/chara_state28.cc Sat Jan 15 19:13:03 2011 +0900 +++ b/spe/chara_state28.cc Fri Jan 21 22:18:28 2011 +0900 @@ -1,12 +1,25 @@ -#include "chara_state28.h" -#include "tobject.h" +#include "task_base.h" +#include "task_object.h" +#include "Sankaku.h" -SchedDefineTask(STATE28); +SchedDefineTask1(State28, state28); static int -run(SchedTask *smanager, void *rbuf, void *wbuf) +state28(SchedTask *smanager, void *rbuf, void *wbuf) { + int rand = (int)smanager->get_param(2); + + int length = 2; CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0); + int count = *(int*)smanager->get_input(rbuf, 1); + + smanager->set_outputSize(4, sizeof(ObjContainer)+sizeof(ObjData)*(length-1)); + smanager->setup_outputData(); + + CHARACTER *q = (CHARACTER*)smanager->get_output(wbuf, 0); + int *w_count = (int*)smanager->get_output(wbuf, 1); + ObjContainerPtr sprite = (ObjContainerPtr)smanager->get_output(wbuf, 4); + sprite->flag = true; if (p->dt1 <= 360) { @@ -19,16 +32,22 @@ p->y = Mysin(p->dt1) * 30 / SANKAKU + 30; } count++; - PutSprite(count, p->x - 42, p->y, 64); + PutSprite(count, p->x - 42, p->y, 64, &sprite->data[0]); if (p->dt1 % 30 == 3) { Putenemy(24, p->x + 14, p->y + 14, - (rand() % 5 + 0.5) * (rand() % 2 == + (rand % 5 + 0.5) * (rand % 2 == 1 ? -1 : 1), - (rand() % 5 + 0.5) * (rand() % 2 == - 1 ? -1 : 1), chara_state29); + (rand % 5 + 0.5) * (rand % 2 == + 1 ? -1 : 1), STATE29, &sprite->data[1]); + } else { + length = 1; } p->dt1 += 3; + + sprite->length = length; + *q = *p; + *w_count = count; return 0; }