changeset 882:1cb89ec2e796 draft

SceneGraphRoot::set_move_task add.
author tkaito
date Mon, 12 Jul 2010 04:02:14 +0900
parents 2919078d069f
children 067fe23c5903
files Renderer/Engine/SceneGraph.cc Renderer/Engine/SceneGraph.h Renderer/Engine/SceneGraphRoot.cc Renderer/Engine/SceneGraphRoot.h Renderer/Engine/task/Draw.cc Renderer/Engine/task/DrawSpan.cc
diffstat 6 files changed, 27 insertions(+), 7 deletions(-) [+]
line wrap: on
line diff
--- a/Renderer/Engine/SceneGraph.cc	Tue Jul 06 10:39:41 2010 +0900
+++ b/Renderer/Engine/SceneGraph.cc	Mon Jul 12 04:02:14 2010 +0900
@@ -650,7 +650,6 @@
     this->create_sg = new_create_sg;
 }
 
-
 void
 SceneGraph::add_next(SceneGraphPtr next)
 {
--- a/Renderer/Engine/SceneGraph.h	Tue Jul 06 10:39:41 2010 +0900
+++ b/Renderer/Engine/SceneGraph.h	Mon Jul 12 04:02:14 2010 +0900
@@ -36,8 +36,9 @@
 
     int property_size;
     void *propertyptr;
-    //void *property;
-    //void *update_property;
+    int move_id;
+    int coll_id;
+    PostFunction post_func;
     memaddr property;
     memaddr update_property;
 
@@ -93,7 +94,6 @@
     void set_move_collision(move_func new_move, collision_func new_collision);
     void set_move_collision(move_func new_move, collision_func new_collision, void *sgroot);
     void set_move_collision(move_func new_move, collision_func new_collision, create_sg_func new_create_sg);
-    void set_game_task(void *sgroot_, int id, void *property, int size, PostFunction post_func);
     void remove(void);
     SceneGraphPtr realRemoveFromTree(SceneGraphPtr tree);
     SceneGraphPtr realRemoveFromList(SceneGraphPtr list);
--- a/Renderer/Engine/SceneGraphRoot.cc	Tue Jul 06 10:39:41 2010 +0900
+++ b/Renderer/Engine/SceneGraphRoot.cc	Mon Jul 12 04:02:14 2010 +0900
@@ -710,5 +710,25 @@
   task->spawn();
 }
 
+static void
+main_task_move(SceneGraphPtr node, void *sgroot_, int screen_w, int screen_h)
+{
+  int size = node->property_size;
+  void *e  = node->propertyptr;
+  int move = node->move_id;
+  PostFunction post_func = node->post_func;
+  sgroot->set_game_task(move, (void*)e, size, post_func);
+}
+
+void
+SceneGraphRoot::set_move_task(SceneGraphPtr node, int move, void *property, int size, 
+			      PostFunction post_func)
+{
+    node->move = main_task_move;
+    node->post_func = post_func;
+    node->move_id = move;
+    node->propertyptr = property;
+    node->property_size = size;
+}
 
 /* end */
--- a/Renderer/Engine/SceneGraphRoot.h	Tue Jul 06 10:39:41 2010 +0900
+++ b/Renderer/Engine/SceneGraphRoot.h	Mon Jul 12 04:02:14 2010 +0900
@@ -106,6 +106,8 @@
     void OnLightSysSwitch();
     void OffLightSysSwitch();
     void set_game_task(int id, void *property, int size, PostFunction post_func);
+    void set_move_task(SceneGraphPtr node, int move, void *property, int size, PostFunction post_func);
+    
 
     /* Other System API */
     void allExecute(int screen_w, int screen_h);
--- a/Renderer/Engine/task/Draw.cc	Tue Jul 06 10:39:41 2010 +0900
+++ b/Renderer/Engine/task/Draw.cc	Mon Jul 12 04:02:14 2010 +0900
@@ -91,7 +91,6 @@
     free(free_pp);
     free(free_spack);
     free(vMid10);
-
+#endif
     return 0;
-#endif
 }
--- a/Renderer/Engine/task/DrawSpan.cc	Tue Jul 06 10:39:41 2010 +0900
+++ b/Renderer/Engine/task/DrawSpan.cc	Mon Jul 12 04:02:14 2010 +0900
@@ -195,7 +195,7 @@
     int alpha = color & 0xff000000;
 #endif
 
-    int *light_sysswitch = (int*)smanager->global_get(LightSysSwitch);
+    //int *light_sysswitch = (int*)smanager->global_get(LightSysSwitch);
 
 
     /*完全に透けているか判断, 法線ベクトルが奥を向いてるかどうか*/