Mercurial > hg > Game > Cerium
changeset 450:baefa979bb31 draft
KeyStat fixed...
author | kazz@henri.cr.ie.u-ryukyu.ac.jp |
---|---|
date | Fri, 25 Sep 2009 22:04:17 +0900 |
parents | 0bed2a9889f5 |
children | 682a9bb1e2cc |
files | TaskManager/Test/test_render/Application/ball_bound.cc TaskManager/Test/test_render/Application/panel.cc TaskManager/Test/test_render/SceneGraphRoot.cc TaskManager/Test/test_render/spe/spe-main.cc TaskManager/Test/test_render/task/UpdateKey.cc TaskManager/Test/test_render/viewer.cc example/word_count/spe/spe-main.cc |
diffstat | 7 files changed, 150 insertions(+), 142 deletions(-) [+] |
line wrap: on
line diff
--- a/TaskManager/Test/test_render/Application/ball_bound.cc Fri Sep 25 18:06:01 2009 +0900 +++ b/TaskManager/Test/test_render/Application/ball_bound.cc Fri Sep 25 22:04:17 2009 +0900 @@ -27,25 +27,25 @@ Pad *pad = sgroot->getController(); if (pad->circle.isHold()) { - if (pad->left.isHold()) { - node->xyz[0] -= speed; - if(node->xyz[0] < ball_radius) - node->xyz[0] = ball_radius; - } else if (pad->right.isHold()) { - node->xyz[0] += speed; - if(node->xyz[0] > screen_w - ball_radius) - node->xyz[0] = screen_w - ball_radius; - } + if (pad->left.isHold()) { + node->xyz[0] -= speed; + if(node->xyz[0] < ball_radius) + node->xyz[0] = ball_radius; + } else if (pad->right.isHold()) { + node->xyz[0] += speed; + if(node->xyz[0] > screen_w - ball_radius) + node->xyz[0] = screen_w - ball_radius; + } - if (pad->up.isHold()) { - node->xyz[1] -= speed; - } else if (pad->down.isHold()) { - node->xyz[1] += speed; + if (pad->up.isHold()) { + node->xyz[1] -= speed; + } else if (pad->down.isHold()) { + node->xyz[1] += speed; if(node->xyz[1] > screen_h - ball_radius) - node->xyz[1] = screen_h - ball_radius; - } + node->xyz[1] = screen_h - ball_radius; + } } else { - node->set_move_collision(ball_move, ball_collision); + node->set_move_collision(ball_move, ball_collision); } } @@ -57,20 +57,20 @@ Pad *pad = sgroot->getController(); if (pad->circle.isPush()) { - node->set_move_collision(ball_move_idle2, ball_collision_idle); - time = 0; + node->set_move_collision(ball_move_idle2, ball_collision_idle); + time = 0; } time++; if (time > 90) { - float w = (float)random(); + float w = (float)random(); - w = fmodf(w, screen_w - ball_radius*2); - node->xyz[0] = w + ball_radius; - node->xyz[1] = h0; - node->set_move_collision(ball_move, ball_collision); - time = 0; + w = fmodf(w, screen_w - ball_radius*2); + node->xyz[0] = w + ball_radius; + node->xyz[1] = h0; + node->set_move_collision(ball_move, ball_collision); + time = 0; } } @@ -89,16 +89,16 @@ static void ball_collision(SceneGraphPtr node, int screen_w, int screen_h, - SceneGraphPtr tree) + SceneGraphPtr tree) { if (node->xyz[1] > screen_h - ball_radius) { - node->xyz[1] = screen_h - ball_radius; + node->xyz[1] = screen_h - ball_radius; - vy *= e; - if (vy > -g && vy < 0) { - vy = 0.0; - node->set_move_collision(ball_move_idle, ball_collision_idle); - } + vy *= e; + if (vy > -g && vy < 0) { + vy = 0.0; + node->set_move_collision(ball_move_idle, ball_collision_idle); + } } }
--- a/TaskManager/Test/test_render/Application/panel.cc Fri Sep 25 18:06:01 2009 +0900 +++ b/TaskManager/Test/test_render/Application/panel.cc Fri Sep 25 22:04:17 2009 +0900 @@ -22,14 +22,14 @@ SceneGraphPtr panel; if (bg == 2) { - sgroot->createFromXMLfile(manager, "xml_file/panel_512.xml"); - panel = sgroot->createSceneGraph(PANEL_512); + sgroot->createFromXMLfile(manager, "xml_file/panel_512.xml"); + panel = sgroot->createSceneGraph(PANEL_512); } else if (bg == 3) { - sgroot->createFromXMLfile(manager, "xml_file/panel_1024.xml"); - panel = sgroot->createSceneGraph(PANEL_1024); + sgroot->createFromXMLfile(manager, "xml_file/panel_1024.xml"); + panel = sgroot->createSceneGraph(PANEL_1024); } else { - sgroot->createFromXMLfile(manager, "xml_file/panel_2048.xml"); - panel = sgroot->createSceneGraph(PANEL_2048); + sgroot->createFromXMLfile(manager, "xml_file/panel_2048.xml"); + panel = sgroot->createSceneGraph(PANEL_2048); } panel->set_move_collision(panel_move, panel_collision);
--- a/TaskManager/Test/test_render/SceneGraphRoot.cc Fri Sep 25 18:06:01 2009 +0900 +++ b/TaskManager/Test/test_render/SceneGraphRoot.cc Fri Sep 25 22:04:17 2009 +0900 @@ -33,19 +33,19 @@ SceneGraphPtr p = sg_available_list; while (p) { - SceneGraphPtr tmp = p->next; - delete p; - p = tmp; - cnt--; + SceneGraphPtr tmp = p->next; + delete p; + p = tmp; + cnt--; } p = sg_remove_list; while (p) { - SceneGraphPtr tmp = p->next; - delete p; - p = tmp; - cnt--; + SceneGraphPtr tmp = p->next; + delete p; + p = tmp; + cnt--; } delete [] sg_src; @@ -63,15 +63,15 @@ SceneGraphRoot::registSceneGraph(SceneGraphPtr sg) { for (int i = 0; i < SGLIST_LENGTH; i++) { - if (strcmp(sg->name, sglist_table[i]) == 0) { - sg->sgid = i; - sg_src[i] = sg; - return; - } + if (strcmp(sg->name, sglist_table[i]) == 0) { + sg->sgid = i; + sg_src[i] = sg; + return; + } } fprintf(stderr, "error: (%s:%3d) Can't find Scene \"%s\"\n", - __FUNCTION__, __LINE__, sg->name); + __FUNCTION__, __LINE__, sg->name); } void @@ -80,13 +80,13 @@ SceneGraphPtr last = sg_available_list; if (!last) { - sg_available_list = sg; + sg_available_list = sg; } else { - while (last->next) { - last = last->next; - } - last->next = sg; - sg->prev = last; + while (last->next) { + last = last->next; + } + last->next = sg; + sg->prev = last; } cnt++; @@ -109,15 +109,15 @@ /* XMLのノードを一つずつ解析 */ for (cur=cur->children; cur; cur=cur->next) { - /* 扱うのはsurfaceオンリー */ - if (xmlStrcmp(cur->name,(xmlChar*)"surface") != 0) { - continue; - } + /* 扱うのはsurfaceオンリー */ + if (xmlStrcmp(cur->name,(xmlChar*)"surface") != 0) { + continue; + } - /* ポリゴン(SceneGraph)生成 */ - tmp = new SceneGraph(manager, cur); + /* ポリゴン(SceneGraph)生成 */ + tmp = new SceneGraph(manager, cur); - registSceneGraph(tmp); + registSceneGraph(tmp); } xmlFreeDoc(doc); @@ -130,7 +130,7 @@ SceneGraphPtr p; if (id < 0 || id > SGLIST_LENGTH) { - return NULL; + return NULL; } /* オリジナルの SceneGraph */ @@ -192,17 +192,17 @@ list = list->next; if(sg_exec_tree != NULL) { - return; + return; } /*removeのflagをもとにtreeを形成*/ /* spe から送り返されてきた property の配列を見て生成する for()*/ /* - for (Property *t = property[0]; is_end(t); t++){ - SceneGraphPtr s = application->scenegraph_factory(t); // SceneGraphNode を作る - t->scenegraph = s; // property list には SceneGraphへのポインタが入っている - application->scenegraph_connector(property[0], s); // add する - } + for (Property *t = property[0]; is_end(t); t++){ + SceneGraphPtr s = application->scenegraph_factory(t); // SceneGraphNode を作る + t->scenegraph = s; // property list には SceneGraphへのポインタが入っている + application->scenegraph_connector(property[0], s); // add する + } */ @@ -250,49 +250,49 @@ list->move_execute(screen_w, screen_h); list->collision_check(screen_w, screen_h, list); - list->frame++; + list->frame++; list = list->next; } if(sg_exec_tree != NULL) { - return; + return; } /*removeのflagをもとにtreeを形成*/ while (t) { - SceneGraphPtr c = NULL; - if (!t->isRemoved()) { - c = t->clone(); - addNext(c); - cur_parent->addChild(c); - c->frame = t->frame; + SceneGraphPtr c = NULL; + if (!t->isRemoved()) { + c = t->clone(); + addNext(c); + cur_parent->addChild(c); + c->frame = t->frame; /*親の回転、座標から、子の回転、座標を算出*/ get_matrix(c->matrix, c->angle, c->xyz, cur_parent->matrix); } - if (t->children != NULL && c != NULL) { - cur_parent = c; - t = t->children; - } else if (t->brother != NULL) { - t = t->brother; - } else { - while (t) { - if (t->brother != NULL) { - t = t->brother; - break; + if (t->children != NULL && c != NULL) { + cur_parent = c; + t = t->children; + } else if (t->brother != NULL) { + t = t->brother; } else { - if (t->parent == NULL) { - t = NULL; - break; - } else { + while (t) { + if (t->brother != NULL) { + t = t->brother; + break; + } else { + if (t->parent == NULL) { + t = NULL; + break; + } else { cur_parent = cur_parent->parent; t = t->parent; - } + } + } + } } - } - } } @@ -314,10 +314,10 @@ SceneGraphPtr p = list; while (p) { - SceneGraphPtr p1 = p->next; - delete p; - p = p1; - cnt--; + SceneGraphPtr p1 = p->next; + delete p; + p = p1; + cnt--; } } @@ -328,13 +328,13 @@ SceneGraphPtr p1; while (p) { - p1 = p->next; - if (p->isRemoved()) { - sg_exec_tree = p->realRemoveFromTree(sg_exec_tree); - sg_available_list = p->realRemoveFromList(sg_available_list); - } - delete p; - p = p1; + p1 = p->next; + if (p->isRemoved()) { + sg_exec_tree = p->realRemoveFromTree(sg_exec_tree); + sg_available_list = p->realRemoveFromList(sg_available_list); + } + delete p; + p = p1; } }
--- a/TaskManager/Test/test_render/spe/spe-main.cc Fri Sep 25 18:06:01 2009 +0900 +++ b/TaskManager/Test/test_render/spe/spe-main.cc Fri Sep 25 22:04:17 2009 +0900 @@ -15,6 +15,9 @@ SchedExternTask(ShowTime); +SchedExternTask(InitKey); +SchedExternTask(UpdateKey); + void task_init(Scheduler *s) { @@ -33,4 +36,7 @@ //SchedRegisterTask(TASK_CREATE_PP, CreatePolygon); SchedRegisterTask(SHOW_TIME, ShowTime); + + SchedRegisterTask(INIT_KEY_TASK, InitKey); + SchedRegisterTask(UPDATE_KEY, UpdateKey); }
--- a/TaskManager/Test/test_render/task/UpdateKey.cc Fri Sep 25 18:06:01 2009 +0900 +++ b/TaskManager/Test/test_render/task/UpdateKey.cc Fri Sep 25 22:04:17 2009 +0900 @@ -8,7 +8,7 @@ int UpdateKey::run(SchedTask *smanager, void *rbuf, void *wbuf) { - key_stat *key = (key_stat*)smanager->get_input(0); + key_stat *key = (key_stat*)smanager->get_input(rbuf, 0); key_stat *gdata = (key_stat*)smanager->global_get(KEY_STATUS); memcpy(gdata, key, sizeof(key_stat));
--- a/TaskManager/Test/test_render/viewer.cc Fri Sep 25 18:06:01 2009 +0900 +++ b/TaskManager/Test/test_render/viewer.cc Fri Sep 25 22:04:17 2009 +0900 @@ -121,54 +121,54 @@ switch (sg_number) { case 0: case 1: - create_cube_split(manager, sg_number); + create_cube_split(manager, sg_number); break; case 2: case 3: case 4: - panel_init(manager, sg_number); + panel_init(manager, sg_number); break; case 5: - universe_init(manager); + universe_init(manager); break; case 6: - ieshoot_init(manager); + ieshoot_init(manager); break; case 7: - ball_bound_init(manager, this->width, this->height); + ball_bound_init(manager, this->width, this->height); break; case 8: - lcube_init(manager, this->width, this->height); + lcube_init(manager, this->width, this->height); break; case 9: - direction_init(manager); + direction_init(manager); break; case 10: - init_position(manager, this->width, this->height); + init_position(manager, this->width, this->height); break; case 11: // vacuum_init(manager, this->width, this->height); break; case 12: - untitled_init(manager); + untitled_init(manager); break; case 13: - boss1_init(manager, this->width, this->height); + boss1_init(manager, this->width, this->height); break; case 14: - init_gaplant(manager, this->width, this->height); + init_gaplant(manager, this->width, this->height); break; case 15: - vacuum_init2(manager, this->width, this->height); + vacuum_init2(manager, this->width, this->height); break; case 16: chain_init(manager, this->width, this-> height); - speLoop(); - return; + speLoop(); + return; break; case 17: chain_old_init(manager, this->width, this-> height); - break; + break; default: node_init(manager); break; @@ -220,7 +220,7 @@ task_tex = manager->create_task(TASK_INIT_TEXTURE); /* * ここはもう少しわかりやすい使い方がいいかもしれぬ。こんなもん? - */ + */ task_tex->set_cpu((CPU_TYPE)((int)SPE_0 + i)); task_next->wait_for(task_tex); task_tex->spawn(); @@ -236,6 +236,7 @@ HTaskPtr task_next = initLoop(); // key の情報を格納する領域を確保する (global_alloc(KEY_STATUS)) HTaskPtr init_key_task = manager->create_task(INIT_KEY_TASK); + init_key_task->set_cpu(SPE_0); init_key_task->spawn(); // SPE に送信する KEY_STATUS の領域確保 @@ -260,43 +261,43 @@ { Pad *pad = sgroot->getController(); if (pad->right.isHold()) { - keyPtr->right = HOLD; + keyPtr->right = HOLD; } else if (pad->right.isPush()) { - keyPtr->right = PUSH; + keyPtr->right = PUSH; } else { - keyPtr->right = NONE; + keyPtr->right = NONE; } if (pad->left.isHold()) { - keyPtr->left = HOLD; + keyPtr->left = HOLD; } else if (pad->left.isPush()) { - keyPtr->left = PUSH; + keyPtr->left = PUSH; } else { - keyPtr->left = NONE; + keyPtr->left = NONE; } if (pad->up.isHold()) { - keyPtr->up = HOLD; + keyPtr->up = HOLD; } else if (pad->up.isPush()) { - keyPtr->up = PUSH; + keyPtr->up = PUSH; } else { - keyPtr->up = NONE; + keyPtr->up = NONE; } if (pad->down.isHold()) { - keyPtr->down = HOLD; + keyPtr->down = HOLD; } else if (pad->down.isPush()) { - keyPtr->down = PUSH; + keyPtr->down = PUSH; } else { - keyPtr->down = NONE; + keyPtr->down = NONE; } if (pad->circle.isHold()) { - keyPtr->circle = HOLD; + keyPtr->circle = HOLD; } else if (pad->circle.isPush()) { - keyPtr->circle = PUSH; + keyPtr->circle = PUSH; } else { - keyPtr->circle = NONE; + keyPtr->circle = NONE; } } @@ -312,6 +313,7 @@ viewer->getKey(); HTaskPtr update_key = viewer->manager->create_task(UPDATE_KEY); update_key->add_inData(viewer->keyPtr, sizeof(key_stat)); + update_key->set_cpu(SPE_0); update_key->spawn(); /* TASK_MOVE は外から引数で取ってくるべき */ @@ -391,7 +393,7 @@ int index_end = (index_start + range >= spackList_length) ? spackList_length : index_start + range; - HTaskPtr task_create_sp = manager->create_task(TASK_CREATE_SPAN); + HTaskPtr task_create_sp = manager->create_task(TASK_CREATE_SPAN); task_create_sp->add_inData(ppack, sizeof(PolygonPack)); task_create_sp->add_inData(spackList_ptr, sizeof(SpanPack*)*spackList_length_align); @@ -503,7 +505,7 @@ } else { memset(&pixels[(startx-1)+this->width*(starty-1)], 0, (this->width)*sizeof(int)*rangey); - break; + break; } task_draw->add_param(startx);
--- a/example/word_count/spe/spe-main.cc Fri Sep 25 18:06:01 2009 +0900 +++ b/example/word_count/spe/spe-main.cc Fri Sep 25 22:04:17 2009 +0900 @@ -9,7 +9,7 @@ * 必ずこの関数名でお願いします。 */ void -task_init(void) +task_init(Scheduler *s) { SchedRegisterTask(TASK_PRINT, Print); SchedRegisterTask(TASK_EXEC, Exec);