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;
 }