Mercurial > hg > Game > Cerium
changeset 529:3527ba243767 draft
modify applications not using SGid but SGname.
author | kent <kent@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Thu, 22 Oct 2009 16:47:49 +0900 |
parents | 7243d7e09d5b |
children | b5f49bab9bd3 |
files | TaskManager/Test/test_render/Application/Chain.cc TaskManager/Test/test_render/Application/ball_bound.cc TaskManager/Test/test_render/Application/gaplant.cc TaskManager/Test/test_render/Application/gaplant_action.cc TaskManager/Test/test_render/Application/universe.cc TaskManager/Test/test_render/Application/untitled.cc TaskManager/Test/test_render/Application/vacuum.cc TaskManager/Test/test_render/Application/vacuum.h TaskManager/Test/test_render/SceneGraphRoot.cc |
diffstat | 9 files changed, 125 insertions(+), 53 deletions(-) [+] |
line wrap: on
line diff
--- a/TaskManager/Test/test_render/Application/Chain.cc Thu Oct 22 13:53:29 2009 +0900 +++ b/TaskManager/Test/test_render/Application/Chain.cc Thu Oct 22 16:47:49 2009 +0900 @@ -213,8 +213,7 @@ // 未実装 char *data = {"1"}; int len = 0; - sgroot->createFromXMLmemory(manager, data, len); - //sgroot->createFromXMLmemory(manager, "xml_file/chain.xml"); + sgroot->createFromXMLfile(manager, "xml_file/chain.xml"); /* SPE に送る property の配列の領域確保 */ properties[0] = (ChainPropertyPtr)manager->allocate(sizeof(ChainProperty)*CHAIN_LEN);
--- a/TaskManager/Test/test_render/Application/ball_bound.cc Thu Oct 22 13:53:29 2009 +0900 +++ b/TaskManager/Test/test_render/Application/ball_bound.cc Thu Oct 22 16:47:49 2009 +0900 @@ -111,12 +111,10 @@ // random な値が欲しいなら、man random に方法が書いてあります。 srandom(100); - // 未実装 char *data = {"1"}; int len = 0; - sgroot->createFromXMLmemory(manager, data, len); - //sgroot->createFromXMLmemory(manager, "xml_file/Ball.xml"); + sgroot->createFromXMLfile(manager, "xml_file/Ball.xml"); ball = sgroot->createSceneGraph("Ball"); ball->set_move_collision(ball_move, ball_collision);
--- a/TaskManager/Test/test_render/Application/gaplant.cc Thu Oct 22 13:53:29 2009 +0900 +++ b/TaskManager/Test/test_render/Application/gaplant.cc Thu Oct 22 16:47:49 2009 +0900 @@ -2,32 +2,116 @@ #include "gaplant_action.h" #include "back_action.h" +SceneGraphPtr +create_gaplant() { + SceneGraphPtr base; + SceneGraphPtr p; + + base = sgroot->createSceneGraph(); + +p = sgroot->createSceneGraph("arm_L_D" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_L_B" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_L_E" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_L_C" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_L_C" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_L_G" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_L_E" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_R_F" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_R_A" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_R_E" ), base->addChild(p); +p = sgroot->createSceneGraph("shoulder_R_C" ), base->addChild(p); +p = sgroot->createSceneGraph("shoulder_R_B" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_L_A" ), base->addChild(p); +p = sgroot->createSceneGraph("shoulder_R_A" ), base->addChild(p); +p = sgroot->createSceneGraph("head_E" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_L_E" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_L_D" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_R_D" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_L_A" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_R_C" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_R_B" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_L_C" ), base->addChild(p); +p = sgroot->createSceneGraph("eye" ), base->addChild(p); +p = sgroot->createSceneGraph("booster_B" ), base->addChild(p); +p = sgroot->createSceneGraph("booster_A" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_R_A" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_center_A" ), base->addChild(p); +p = sgroot->createSceneGraph("shoulder_L_A" ), base->addChild(p); +p = sgroot->createSceneGraph("body_A" ), base->addChild(p); +p = sgroot->createSceneGraph("body_B" ), base->addChild(p); +p = sgroot->createSceneGraph("body_C" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_center_B" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_R_C" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_L_C" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_L_B" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_R_B" ), base->addChild(p); +p = sgroot->createSceneGraph("west_D" ), base->addChild(p); +p = sgroot->createSceneGraph("west_A" ), base->addChild(p); +p = sgroot->createSceneGraph("west_B" ), base->addChild(p); +p = sgroot->createSceneGraph("body_L_A" ), base->addChild(p); +p = sgroot->createSceneGraph("body_R_A" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_center_C" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_B" ), base->addChild(p); +p = sgroot->createSceneGraph("head_C" ), base->addChild(p); +p = sgroot->createSceneGraph("head_F" ), base->addChild(p); +p = sgroot->createSceneGraph("head_D" ), base->addChild(p); +p = sgroot->createSceneGraph("head_R_B" ), base->addChild(p); +p = sgroot->createSceneGraph("head_L_B" ), base->addChild(p); +p = sgroot->createSceneGraph("head_L_A" ), base->addChild(p); +p = sgroot->createSceneGraph("head_R_A" ), base->addChild(p); +p = sgroot->createSceneGraph("head_B" ), base->addChild(p); +p = sgroot->createSceneGraph("head_A" ), base->addChild(p); +p = sgroot->createSceneGraph("shoulder_L_B" ), base->addChild(p); +p = sgroot->createSceneGraph("shoulder_L_C" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_L_A" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_L_B" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_R_D" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_L_F" ), base->addChild(p); +p = sgroot->createSceneGraph("arm_R_G" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_R_C" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_R_E" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_L_B" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_R_B" ), base->addChild(p); +p = sgroot->createSceneGraph("shield_R_A" ), base->addChild(p); +p = sgroot->createSceneGraph("west_C" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_L_D" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_R_D" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_L_F" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_R_F" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_R_C" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_R_E" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_R_A" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_R_B" ), base->addChild(p); +p = sgroot->createSceneGraph("chest_A" ), base->addChild(p); +p = sgroot->createSceneGraph("foot_L_A" ), base->addChild(p); + + return base; +} + void init_gaplant(TaskManager *manager, int w, int h) { SceneGraphPtr back; SceneGraphPtr gaplant; - //sgroot->createFromXMLmemory(manager, "xml_file/gap_plane_test.xml"); - //sgroot->createFromXMLmemory(manager, "xml_file/Ball.xml"); - // 未実装 - char *data = {"1"}; + sgroot->createFromXMLfile(manager, "xml_file/gap_plane_test.xml"); + sgroot->createFromXMLfile(manager, "xml_file/Ball.xml"); int len = 0; - sgroot->createFromXMLmemory(manager, data, len); back = sgroot->createSceneGraph(); back->set_move_collision(back_move, back_coll); - gaplant = sgroot->createSceneGraph(); + gaplant = create_gaplant(); + /* + for (int i = arm_L_D; i <= foot_L_A; i++) { + SceneGraphPtr p = sgroot->createSceneGraph(i); + gaplant->addChild(p); + } + */ gaplant->xyz[0] = 200; gaplant->angle[0] = -60; gaplant->angle[1] = 0; gaplant->angle[2] = 0; gaplant->set_move_collision(gaplant_move, gaplant_coll); -#if 0 - for (int i = arm_L_D; i <= foot_L_A; i++) { - SceneGraphPtr p = sgroot->createSceneGraph(i); - gaplant->addChild(p); - } -#endif back->addChild(gaplant); sgroot->setSceneData(back); } +
--- a/TaskManager/Test/test_render/Application/gaplant_action.cc Thu Oct 22 13:53:29 2009 +0900 +++ b/TaskManager/Test/test_render/Application/gaplant_action.cc Thu Oct 22 16:47:49 2009 +0900 @@ -77,22 +77,20 @@ void gaplant_coll(SceneGraphPtr node, int w, int h, SceneGraphPtr tree) { - //SceneGraphIteratorPtr it = sgroot->getIterator(tree); - //static int damage = 0; -#if 0 - for (; it->hasNext(Ball);) { - it->next(Ball); + SceneGraphIteratorPtr it = sgroot->getIterator(tree); + static int damage = 0; + for (; it->hasNext(sgroot->sglist->get("Ball")->id);) { + it->next(sgroot->sglist->get("Ball")->id); SceneGraphPtr ball = it->get(); double dis_x = node->xyz[0] - ball->xyz[0]; double dis_y = node->xyz[1] - ball->xyz[1]; double dis_z = node->xyz[2] - ball->xyz[2]; double distance = sqrt(dis_x*dis_x + dis_y*dis_y + dis_z*dis_z); - + if (distance < CHECK_HIT_RAD + BALL_RAD) { cout << "今からもっと細かく判定するよ ^q^\n"; ball->remove(); } } -#endif }
--- a/TaskManager/Test/test_render/Application/universe.cc Thu Oct 22 13:53:29 2009 +0900 +++ b/TaskManager/Test/test_render/Application/universe.cc Thu Oct 22 16:47:49 2009 +0900 @@ -46,11 +46,10 @@ SceneGraphPtr earth; SceneGraphPtr moon; - //sgroot->createFromXMLmemory(manager, "xml_file/universe.xml"); + sgroot->createFromXMLfile(manager, "xml_file/universe.xml"); // 未実装 char *data = {"1"}; int len = 0; - sgroot->createFromXMLmemory(manager, data, len); // SGList.h にある SceneGraph ID から SceneGraph を生成する earth = sgroot->createSceneGraph("Earth");
--- a/TaskManager/Test/test_render/Application/untitled.cc Thu Oct 22 13:53:29 2009 +0900 +++ b/TaskManager/Test/test_render/Application/untitled.cc Thu Oct 22 16:47:49 2009 +0900 @@ -86,11 +86,9 @@ SceneGraphPtr test08; SceneGraphPtr test09; - //sgroot->createFromXMLmemory(manager, "xml_file/Venus.xml"); - // 未実装 + sgroot->createFromXMLfile(manager, "xml_file/Venus.xml"); char *data = {"1"}; int len = 0; - sgroot->createFromXMLmemory(manager, data, len); // SGList.h にある SceneGraph ID から SceneGraph を生成する /*
--- a/TaskManager/Test/test_render/Application/vacuum.cc Thu Oct 22 13:53:29 2009 +0900 +++ b/TaskManager/Test/test_render/Application/vacuum.cc Thu Oct 22 16:47:49 2009 +0900 @@ -30,15 +30,14 @@ vacuum_coll(SceneGraphPtr node, int screen_w, int screen_h, SceneGraphPtr tree) { -#if 0 Pad *pad = sgroot->getController(); if(node->frame%ENCOUNT == ENCOUNT-1) { if(random()%2) { - add_cubecollision_object(REDCUBE,node,screen_w,screen_h); + add_cubecollision_object("REDCUBE",node,screen_w,screen_h); } else { - add_cubecollision_object(ENEMY,node,screen_w,screen_h); + add_cubecollision_object("ENEMY",node,screen_w,screen_h); } } @@ -53,21 +52,19 @@ SceneGraphIteratorPtr it = sgroot->getIterator(tree); lock_attack(node,it); } -#endif } void lock_attack(SceneGraphPtr node,SceneGraphIteratorPtr it) { -#if 0 SceneGraphPtr enemy; SceneGraphPtr near_enemy = NULL; float dx,dy,r,range = 100; // Pad *pad = sgroot->getController(); - for(;it->hasNext(ENEMY);) { + for(;it->hasNext(sgroot->sglist->get("ENEMY")->id);) { - it->next(ENEMY); + it->next(sgroot->sglist->get("ENEMY")->id); enemy = it->get(); dx = enemy->xyz[0] - node->xyz[0]; dy = enemy->xyz[1] - node->xyz[1]; @@ -90,7 +87,6 @@ //near_enemy_common_move->addChild(lockon); near_enemy->addChild(lockon); } -#endif } void @@ -141,7 +137,7 @@ /*cubeをランダムな場所に生成*/ void -add_cubecollision_object(int id,SceneGraphPtr root,int w,int h) +add_cubecollision_object(const char *id,SceneGraphPtr root,int w,int h) { SceneGraphPtr object; SceneGraphPtr common_move; @@ -160,15 +156,13 @@ vacuum_init2(TaskManager *manager, int w, int h) { SceneGraphPtr title; - /* - sgroot->createFromXMLmemory(manager, "xml_file/gamecube.xml"); - sgroot->createFromXMLmemory(manager, "xml_file/title.xml"); - sgroot->createFromXMLmemory(manager, "xml_file/gameover.xml"); - */ + sgroot->createFromXMLfile(manager, "xml_file/gamecube.xml"); + sgroot->createFromXMLfile(manager, "xml_file/title.xml"); + sgroot->createFromXMLfile(manager, "xml_file/gameover.xml"); + // 未実装 char *data = {"1"}; int len = 0; - sgroot->createFromXMLmemory(manager, data, len); title = sgroot->createSceneGraph("TITLE"); title->xyz[0] = w/2;
--- a/TaskManager/Test/test_render/Application/vacuum.h Thu Oct 22 13:53:29 2009 +0900 +++ b/TaskManager/Test/test_render/Application/vacuum.h Thu Oct 22 16:47:49 2009 +0900 @@ -19,7 +19,7 @@ void collision_red(SceneGraphIteratorPtr it,SceneGraphPtr node); void collision_purple(SceneGraphIteratorPtr it,SceneGraphPtr node,int w,int h); void gameover_scene(int w,int h, SceneGraphPtr node); -void add_cubecollision_object(int id,SceneGraphPtr root,int w,int h); +void add_cubecollision_object(const char *id,SceneGraphPtr root,int w,int h); void lock_attack(SceneGraphPtr node,SceneGraphIteratorPtr it); void lockon_collision(SceneGraphPtr node,int w,int h,SceneGraphPtr tree); void cube_rotate(SceneGraphPtr node,int w,int h);
--- a/TaskManager/Test/test_render/SceneGraphRoot.cc Thu Oct 22 13:53:29 2009 +0900 +++ b/TaskManager/Test/test_render/SceneGraphRoot.cc Thu Oct 22 16:47:49 2009 +0900 @@ -106,7 +106,7 @@ xmlDocPtr doc; xmlNodePtr cur; SceneGraphPtr tmp; - + /* パース DOM生成 */ doc = xmlParseFile(xmlfile); cur = xmlDocGetRootElement(doc); @@ -116,18 +116,20 @@ /* 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); + addSceneGraphList(manager, tmp); + registSceneGraphList(tmp); } xmlFreeDoc(doc); + } SceneGraphPtr