changeset 38:6626e451a09d

fix random number.
author koba <koba@cr.ie.u-ryukyu.ac.jp>
date Tue, 11 Jan 2011 16:27:01 +0900 (2011-01-11)
parents 6989f8cb0259
children 5484b8606e8e
files Character.h Character_state.c Dandy.cc TaskDandy.cc ppe/chara_state22.cc ppe/chara_state25.cc ppe/chara_state28.cc ppe/chara_state41.cc ppe/chara_state500.cc ppe/chara_state601.cc ppe/chara_state602.cc state_task.cc
diffstat 12 files changed, 164 insertions(+), 55 deletions(-) [+]
line wrap: on
line diff
--- a/Character.h	Sun Jan 09 23:14:26 2011 +0900
+++ b/Character.h	Tue Jan 11 16:27:01 2011 +0900
@@ -14,6 +14,8 @@
 #define ENEMY 2
 #define ENEMYBULLET 3
 
+#define FIX_NUM 17
+
 //typedef void (*STATE)(CHARACTER *p);
 typedef struct CHARACTER * (*State)(struct CHARACTER *p);
 typedef struct CHARACTER * (*Collision)(struct CHARACTER *p);
--- a/Character_state.c	Sun Jan 09 23:14:26 2011 +0900
+++ b/Character_state.c	Tue Jan 11 16:27:01 2011 +0900
@@ -30,6 +30,15 @@
 int asteroidi = 0;
 int enemyfaste = 0;
 int fastebos = 0;
+int counter = 0;
+
+static
+int get_num()
+{
+    counter++;
+    counter %= 4;
+    return counter;
+}
 
 CHARACTER * noaction(CHARACTER *p)
 {
@@ -427,32 +436,34 @@
 CHARACTER * chara_state22(CHARACTER *p)
 {
   int sf;
+  int rand = get_num();
 
-  sf = rand() % 4;
+  sf = rand % 4;
   if((sf == 0) || (sf == 1))
     {
       p->x = -35;
-      p->y = rand() % (120 - 35);
-      p->vx = (rand() % 4 + 1);
-      p->vy = rand() % 3 + 1;
+      p->y = rand % (120 - 35);
+      p->vx = (rand % 4 + 1);
+      p->vy = rand % 3 + 1;
       p->state = chara_state23;
     }
   if((sf == 2))
     {
-      p->x = rand() % 290;
+      p->x = rand % 290;
       p->y = -30;
-      p->vx = rand() % 3 - 1;
-      p->vy = (rand() % 4 + 1);
+      p->vx = rand % 3 - 1;
+      p->vy = (rand % 4 + 1);
       p->state = chara_state23;
     }
   if(sf == 3)
     {
       p->x = 320;
-      p->y = rand() % (120 - 35);
-      p->vx = (rand() % 4 + 1) * -1;
-      p->vy = rand() % 3 -1;
+      p->y = rand % (120 - 35);
+      p->vx = (rand % 4 + 1) * -1;
+      p->vy = rand % 3 -1;
       p->state = chara_state23;
     }
+  printf("x = %f, y = %f, vx = %f, vy = %f\n",p->x, p->y, p->vx, p->vy);
   return p;
 }
 	  
@@ -482,6 +493,7 @@
 CHARACTER * chara_state25(CHARACTER *p)
 {
   int amari;
+  int rand = get_num();
 
   if(p->dt1 <= 360)
     {
@@ -495,7 +507,7 @@
     }
   count++;
   PutSprite(count, p->x - 42, p->y, 64);
-  amari = rand() % 160;
+  amari = rand % 160;
   if((amari == 1) && (enemy_part5->f == TRUE))
     {
       p->state = chara_state26;
@@ -604,6 +616,8 @@
 }
 CHARACTER * chara_state28(CHARACTER *p)
 {
+  int rand = get_num();
+
   if (p->dt1 <= 360)
     {
       p->x = Mycos(p->dt1) * 30 / SANKAKU + 82 + 32;
@@ -620,9 +634,9 @@
     {
       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 ==
+	       (rand % 5 + 0.5) * (rand % 2 ==
 				     1 ? -1 : 1), chara_state29);
     }
   p->dt1 += 3;
@@ -902,6 +916,8 @@
 
 CHARACTER * chara_state41(CHARACTER *p) //left arm up arm vulkan
 {
+  int rand;
+
   if (enemy_part2->f == FALSE)
     {
       Bom(p->x, p->y);
@@ -929,7 +945,7 @@
     {
       if (p->dt1 % 15 == 1) 
 	{
-	  Puttama(9 + rand() % 2, p->x, p->y);
+	  Puttama(9 + rand % 2, p->x, p->y);
 	}
     }
   if (rinkf1 == 10)
@@ -1057,6 +1073,7 @@
 
 CHARACTER * chara_state500(CHARACTER *p)
 {
+  int rand = get_num();
   p->s = 0;
   
   kyeenemyno = p;
@@ -1070,14 +1087,14 @@
   PutSpriteEx(100, p->x + 16, p->y + 16, 2, 2, p->dt1);
   
   if (p->dt1 % (5 + p->dt2 / 8) == 1) {
-    if (rand() % 2 == 1)
+    if (rand % 2 == 1)
       Putenemy(24, p->x, p->y,
-	       (rand() % 5 + 0.5) * (rand() % 2 ==
+	       (rand % 5 + 0.5) * (rand % 2 ==
 				     1 ? -1 : 1),
-	       (rand() % 5 + 0.5) * (rand() % 2 ==
+	       (rand % 5 + 0.5) * (rand % 2 ==
 				     1 ? -1 : 1), chara_state501);
     else
-      Putenemy(rand() % 2 + 1, p->x,
+      Putenemy(rand % 2 + 1, p->x,
 	       p->y,
 	       (int) Mycos(p->dt1 / 4) * 4 /
 	       SANKAKU,
@@ -1100,6 +1117,7 @@
       Puttama(11, p->x, p->y);
     }
   p->dt1++;
+  printf("x = %f, y = %f, vx = %f, vy = %f\n",p->x, p->y, p->vx, p->vy);
   return p;
 }
 
@@ -1131,14 +1149,15 @@
 
 CHARACTER * chara_state601(CHARACTER *p)
 {
+  int rand = get_num();
   p->dt2++;
   if (p->x < jiki.x)
     p->vx++;
   if (p->x > jiki.x)
     p->vx--;
   p->x += p->vx;
-  Putenemy(6, p->x + 16 + rand() % 32,
-	   p->y, 0, rand() % 4, chara_state400);
+  Putenemy(6, p->x + 16 + rand % 32,
+	   p->y, 0, rand % 4, chara_state400);
   if (p->x < 0)
     p->x = 0;
   if (p->x > 260)
@@ -1156,10 +1175,12 @@
 
 CHARACTER * chara_state602(CHARACTER *p)
 {
+  int rand = get_num();
+
   p->dt2++;
   Putenemy(24, p->x + 14, p->y + 14,
-	   (rand() % 5 + 0.5) * (rand() % 2 == 1 ? -1 : 1),
-	   (rand() % 5 + 0.5) * (rand() % 2 == 1 ? -1 : 1),
+	   (rand % 5 + 0.5) * (rand % 2 == 1 ? -1 : 1),
+	   (rand % 5 + 0.5) * (rand % 2 == 1 ? -1 : 1),
 	   chara_state29);
   if (p->dt2 > 1024) {
     p->state = chara_state600;
@@ -1191,5 +1212,6 @@
 	}
     }
     asteroidi++;
+    //    printf("x = %f, y = %f, vx = %f, vy = %f\n",p->x, p->y, p->vx, p->vy);
     return p;
 }
--- a/Dandy.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/Dandy.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -335,7 +335,7 @@
 	tlv3[i].y = -1;
     }
     filpcount = 0;
-    stage = 0;
+    stage = 4;
     //for (i = 0; i < 300; i++)
     //enemy[i].f = FALSE;
     jiki.zanki = 3;
--- a/TaskDandy.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/TaskDandy.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -69,7 +69,6 @@
 SDL_Joystick *joy;
 
 
-
 const char *usr_help_str = "Usage: ./twice [-length data_length] [-count task_num]\n\
   -length  Number of data (default DATA_NUM (Func.h))\n\
   -count   Number of task (default 1)\n";
@@ -285,10 +284,10 @@
 	asteroidi = 0;
 	// timeprof_begin(timeprof_move);
 	//Move(); //enemy move
-	collision_detect();
 	outofwindow();
 	// timeprof_end(timeprof_move);
 	state_update();
+	collision_detect();
 	//charpatern();
 	//bosguage();
     
@@ -335,7 +334,7 @@
 	tlv3[i].y = -1;
     }
     filpcount = 0;
-    stage = 0;
+    stage = 4;
     //for (i = 0; i < 300; i++)
     //enemy[i].f = FALSE;
     jiki.zanki = 3;
--- a/ppe/chara_state22.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/ppe/chara_state22.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -6,31 +6,33 @@
 static int
 state22(SchedTask *smanager, void *rbuf, void *wbuf)
 {
+    int rand = (int)smanager->get_param(0);
+
     CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0);
 
-      int sf = rand() % 4;
+      int sf = rand % 4;
       if((sf == 0) || (sf == 1))
       {
 	  p->x = -35;
-	  p->y = rand() % (120 - 35);
-	  p->vx = (rand() % 4 + 1);
-	  p->vy = rand() % 3 + 1;
+	  p->y = rand % (120 - 35);
+	  p->vx = (rand % 4 + 1);
+	  p->vy = rand % 3 + 1;
 	  p->task = STATE23;
       }
       if((sf == 2))
       {
-	  p->x = rand() % 290;
+	  p->x = rand % 290;
 	  p->y = -30;
-	  p->vx = rand() % 3 - 1;
-	  p->vy = (rand() % 4 + 1);
+	  p->vx = rand % 3 - 1;
+	  p->vy = (rand % 4 + 1);
 	  p->task = STATE23;
       }
       if(sf == 3)
       {
 	  p->x = 320;
-	  p->y = rand() % (120 - 35);
-	  p->vx = (rand() % 4 + 1) * -1;
-	  p->vy = rand() % 3 -1;
+	  p->y = rand % (120 - 35);
+	  p->vx = (rand % 4 + 1) * -1;
+	  p->vy = rand % 3 -1;
 	  p->task = STATE23;
       }
 
--- a/ppe/chara_state25.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/ppe/chara_state25.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -12,6 +12,7 @@
 
     int part1_f = (int)smanager->get_param(0);
     int part5_f = (int)smanager->get_param(1);
+    int rand = (int)smanager->get_param(2);
 
     CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0);
     int count = *(int*)smanager->get_input(rbuf, 1);
@@ -40,7 +41,7 @@
     count++;
     *w_count = count;
     PutSprite(count, p->x - 42, p->y, 64, &sprite->data[0]);
-    amari = rand() % 160;
+    amari = rand % 160;
     if((amari == 1) && (part5_f == TRUE))
     {
 	p->task = STATE26;
--- a/ppe/chara_state28.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/ppe/chara_state28.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -7,6 +7,8 @@
 static int
 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);
@@ -35,9 +37,9 @@
     {
 	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 ==
+		 (rand % 5 + 0.5) * (rand % 2 ==
 				       1 ? -1 : 1), STATE29, &sprite->data[1]);
     } else {
 	length = 1;
--- a/ppe/chara_state41.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/ppe/chara_state41.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -7,6 +7,7 @@
 state41(SchedTask *smanager, void *rbuf, void *wbuf)
 {
     int enemy_part2_f = (int)smanager->get_param(1);
+    int rand = (int)smanager->get_param(6);
     
     int length;
     CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0);
@@ -59,7 +60,7 @@
 	    sprite->flag = true;
 	    sprite->length = length;
 
-	    Puttama(9 + rand() % 2, p->x, p->y, &sprite->data[0]);
+	    Puttama(9 + rand % 2, p->x, p->y, &sprite->data[0]);
 	}
     }
     if (rinkf1 == 10)
--- a/ppe/chara_state500.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/ppe/chara_state500.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -7,6 +7,8 @@
 static int
 state500(SchedTask *smanager, void *rbuf, void *wbuf)
 {
+    int rand = (int)smanager->get_param(0);
+
     CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0);
     int count = *(int*)smanager->get_input(rbuf, 1);
 
@@ -30,14 +32,14 @@
     if (p->dt1 % (5 + p->dt2 / 8) == 1) {
 	sprite->length = 3;
 
-	if (rand() % 2 == 1)
+	if (rand % 2 == 1)
 	    Putenemy(24, p->x, p->y,
-		     (rand() % 5 + 0.5) * (rand() % 2 ==
+		     (rand % 5 + 0.5) * (rand % 2 ==
 					   1 ? -1 : 1),
-		     (rand() % 5 + 0.5) * (rand() % 2 ==
+		     (rand % 5 + 0.5) * (rand % 2 ==
 					   1 ? -1 : 1), STATE501, &sprite->data[2]);
 	else
-	    Putenemy(rand() % 2 + 1, p->x,
+	    Putenemy(rand % 2 + 1, p->x,
 		     p->y,
 		     (int) Mycos(p->dt1 / 4) * 4 /
 		     SANKAKU,
--- a/ppe/chara_state601.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/ppe/chara_state601.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -6,6 +6,8 @@
 static int
 state601(SchedTask *smanager, void *rbuf, void *wbuf)
 {
+    int rand = (int)smanager->get_param(0);
+
     CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0);
     player *jiki = (player*)smanager->get_input(rbuf, 1);
 
@@ -23,8 +25,8 @@
     if (p->x > jiki->x)
 	p->vx--;
     p->x += p->vx;
-    Putenemy(6, p->x + 16 + rand() % 32,
-	     p->y, 0, rand() % 4, STATE400, &sprite->data[0]);
+    Putenemy(6, p->x + 16 + rand % 32,
+	     p->y, 0, rand % 4, STATE400, &sprite->data[0]);
     if (p->x < 0)
 	p->x = 0;
     if (p->x > 260)
--- a/ppe/chara_state602.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/ppe/chara_state602.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -6,6 +6,8 @@
 static int
 state602(SchedTask *smanager, void *rbuf, void *wbuf)
 {
+    int rand = (int)smanager->get_param(0);
+
     CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0);
 
     int length = 1;
@@ -18,8 +20,8 @@
 
     p->dt2++;
     Putenemy(24, p->x + 14, p->y + 14,
-	     (rand() % 5 + 0.5) * (rand() % 2 == 1 ? -1 : 1),
-	     (rand() % 5 + 0.5) * (rand() % 2 == 1 ? -1 : 1),
+	     (rand % 5 + 0.5) * (rand % 2 == 1 ? -1 : 1),
+	     (rand % 5 + 0.5) * (rand % 2 == 1 ? -1 : 1),
 	     STATE29, &sprite->data[0]);
     if (p->dt2 > 1024) {
 	p->task = STATE600;
--- a/state_task.cc	Sun Jan 09 23:14:26 2011 +0900
+++ b/state_task.cc	Tue Jan 11 16:27:01 2011 +0900
@@ -38,8 +38,18 @@
 int enemyfaste = 0;
 int fastebos = 0;
 
+int counter = 0;
+
 State state_list[LIST_NUM];
 
+/* output 0~3 */
+static
+int get_num()
+{
+    counter++;
+    counter %= 4;
+    return counter;
+}
 
 static
 int power_of_two(int input)
@@ -146,11 +156,24 @@
 
 
 void
+PrintCoordinate(SchedTask *s, void *chara, void *arg)
+{
+    CHARACTER *p = (CHARACTER*)chara;
+    printf("x = %f, y = %f, vx = %f, vy = %f\n",p->x, p->y, p->vx, p->vy);
+
+    int num = GetStateNum(p->task);
+    p->state = state_list[num];
+}
+
+
+void
 freeObject(SchedTask *s, void *chara, void *obj)
 {
     free(obj);
 
     CHARACTER *p = (CHARACTER*)chara;
+//    printf("x = %f, y = %f, vx = %f, vy = %f\n",p->x, p->y, p->vx, p->vy);
+
     int num = GetStateNum(p->task);
     p->state = state_list[num];
 }
@@ -224,6 +247,26 @@
 
 
 CHARACTER*
+FixRandomTask(CHARACTER *p)
+{
+    int task_num = p->task;
+    HTaskPtr state_task = tmanager->create_task(task_num);
+    
+    state_task->set_param(0, (memaddr)get_num());
+
+    state_task->set_inData(0, p, sizeof(CHARACTER));
+
+    state_task->set_outData(0, p, sizeof(CHARACTER));
+
+    state_task->set_post(PrintCoordinate, (void*)p, NULL);
+    state_task->set_cpu(SPE_ANY);
+    state_task->spawn();
+
+    return p;
+}
+
+
+CHARACTER*
 withJikiTask(CHARACTER *p)
 {
     int task_num = p->task;
@@ -257,7 +300,7 @@
     state_task->set_outData(0, p, sizeof(CHARACTER));
     state_task->set_outData(1, obj, 0);
 
-    state_task->set_post(checkContainer, (void*)p, (void*)obj);    
+    state_task->set_post(checkContainer, (void*)p, (void*)obj);
     state_task->set_cpu(SPE_ANY);
     state_task->spawn();
     
@@ -316,7 +359,7 @@
     }
     state_task->set_cpu(SPE_ANY);
     state_task->spawn();
-
+    
     asteroidi++;
     return p;
 }
@@ -500,6 +543,7 @@
 
     state_task->set_param(0, (memaddr)enemy_part1->f);
     state_task->set_param(1, (memaddr)enemy_part5->f);
+    state_task->set_param(2, (memaddr)get_num());
 
     state_task->set_inData(0, p, sizeof(CHARACTER));
     state_task->set_inData(1, &count, sizeof(int));
@@ -536,6 +580,7 @@
     state_task->set_param(3, (memaddr)enemy_part4->f);
     state_task->set_param(4, (memaddr)enemystate[num1].charano);
     state_task->set_param(5, (memaddr)enemystate[num2].charano);
+    state_task->set_param(6, (memaddr)get_num());
 
     state_task->set_inData(0, p, sizeof(CHARACTER));
     state_task->set_inData(1, kyeenemyno, sizeof(CHARACTER));
@@ -566,6 +611,8 @@
     obj->flag = false;
     obj->length = 0;
 
+    state_task->set_param(0, (memaddr)get_num());
+
     state_task->set_inData(0, p, sizeof(CHARACTER));
     state_task->set_inData(1, &count, sizeof(int));
     
@@ -582,6 +629,32 @@
 
 
 CHARACTER*
+Boss5Task(CHARACTER *p)
+{
+    int task_num = p->task;
+    int obj_size = sizeof(ObjContainer)+sizeof(ObjData)*DATA_LENGTH;
+    HTaskPtr state_task = tmanager->create_task(task_num);
+    ObjContainerPtr obj = (ObjContainerPtr)tmanager->allocate(obj_size);
+    obj->flag = false;
+    obj->length = 0;
+
+    state_task->set_param(0, (memaddr)get_num());
+
+    state_task->set_inData(0, p, sizeof(CHARACTER));
+    state_task->set_inData(1, &jiki, sizeof(player));
+
+    state_task->set_outData(0, p, sizeof(CHARACTER));
+    state_task->set_outData(1, obj, 0);
+
+    state_task->set_post(checkContainer, (void*)p, (void*)obj);    
+    state_task->set_cpu(SPE_ANY);
+    state_task->spawn();
+    
+    return p;
+}
+
+
+CHARACTER*
 noaction(CHARACTER *p)
 {
   return p;
@@ -736,8 +809,8 @@
 CHARACTER*
 chara_state22(CHARACTER *p)
 {
-    p->task = STATE22;    
-    return SimpleStateTask(p);
+    p->task = STATE22;
+    return FixRandomTask(p);
 }
 
 
@@ -872,7 +945,8 @@
 }
 
 
-CHARACTER * chara_state400(CHARACTER *p)
+CHARACTER*
+chara_state400(CHARACTER *p)
 {
     p->task = STATE400;
     return SimpleStateTask(p);
@@ -944,7 +1018,7 @@
 chara_state601(CHARACTER *p)
 {
     p->task = STATE601;
-    return JikiContainerTask(p);
+    return Boss5Task(p);
 }
 
 
@@ -952,5 +1026,5 @@
 chara_state602(CHARACTER *p)
 {
     p->task = STATE602;
-    return sendContainerTask(p);
+    return Boss5Task(p);
 }