diff spe/chara_state11.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_state11.cc	Sat Jan 15 19:13:03 2011 +0900
+++ b/spe/chara_state11.cc	Fri Jan 21 22:18:28 2011 +0900
@@ -1,23 +1,43 @@
-#include "chara_state11.h"
-#include "tobject.h"
+#include "task_base.h"
+#include "task_object.h"
 
-SchedDefineTask(STATE11);
+SchedDefineTask1(State11, state11);
 
 static int
-run(SchedTask *smanager, void *rbuf, void *wbuf)
+state11(SchedTask *smanager, void *rbuf, void *wbuf)
 {
+    int rinkf1 = (int)smanager->get_param(0);
+    int count = (int)smanager->get_param(1);
+    int length;
     CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0);
 
     if(rinkf1 == 0)
     {
+	length = 2;
+	smanager->set_outputSize(2, 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, 2);
+	sprite->flag = true;
+	sprite->length = length;
+
 	count++;
-	DefSpriteEx(54, 16, 32);
-	PutSpriteEx(54, p->x, p->y, p->s, p->s, 1);
+	DefSpriteEx(54, 16, 32, &sprite->data[0]);
+	PutSpriteEx(54, p->x, p->y, p->s, p->s, 1, &sprite->data[1]);
+
 	p->task = STATE11;
+	*w_count = count;	
+	*q = *p;
 	return 0;
     }
+    CHARACTER *q = (CHARACTER*)smanager->get_output(wbuf, 0);
+    
     p->dt1 = 0;
     p->dt2 = 0;
+
     p->task = STATE12;
+    *q = *p;
     return 0;
 }