changeset 140:67a5469dfef2 draft

add Controller
author gongo@charles.cr.ie.u-ryukyu.ac.jp
date Fri, 28 Nov 2008 15:24:55 +0900
parents bacb6dde2d17
children 56db76a03294
files TaskManager/Test/test_render/Button.cpp TaskManager/Test/test_render/Button.h TaskManager/Test/test_render/Joystick.cpp TaskManager/Test/test_render/Joystick.h TaskManager/Test/test_render/Keyboard.cpp TaskManager/Test/test_render/Keyboard.h TaskManager/Test/test_render/Makefile.def TaskManager/Test/test_render/Pad.h TaskManager/Test/test_render/SceneGraph.cpp TaskManager/Test/test_render/SceneGraph.h TaskManager/Test/test_render/node.cpp TaskManager/Test/test_render/pad.h TaskManager/Test/test_render/viewer.cpp
diffstat 13 files changed, 402 insertions(+), 74 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TaskManager/Test/test_render/Button.cpp	Fri Nov 28 15:24:55 2008 +0900
@@ -0,0 +1,26 @@
+#include "Button.h"
+
+void
+Button::push_work(void)
+{
+#if 0
+    if (hold) {
+	push = 0;
+    } else {
+	push = 1;
+    }
+#else
+    push = (!hold)*1;
+#endif
+
+    hold = 1;
+    release = 0;
+}
+
+void
+Button::release_work(void)
+{
+    push = 0;
+    hold = 0;
+    release = 1;
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TaskManager/Test/test_render/Button.h	Fri Nov 28 15:24:55 2008 +0900
@@ -0,0 +1,16 @@
+#ifndef INCLUDED_BUTTON
+#define INCLUDED_BUTTON
+
+class Button {
+public:
+    int push;
+    int hold;
+    int release;
+
+    Button(void) : push(0), hold(0), release(0) {}
+
+    void push_work(void);
+    void release_work(void);
+};
+
+#endif
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TaskManager/Test/test_render/Joystick.cpp	Fri Nov 28 15:24:55 2008 +0900
@@ -0,0 +1,134 @@
+#include <SDL.h>
+#include "Joystick.h"
+
+static const int CROSS = 0;
+static const int CIRCLE = 1;
+static const int SQUARE = 2;
+static const int TRIANGLE = 3;
+static const int L1 = 4;
+static const int R1 = 5;
+static const int L2 = 6;
+static const int R2 = 7;
+static const int START = 8;
+static const int SELECT = 9;
+static const int L3 = 10;
+static const int R3 = 11;
+static const int UP = 12;
+static const int DOWN = 13;
+static const int RIGHT = 14;
+static const int LEFT = 15;
+static const int ESCAPE = 16;
+static const int SPACE = 17;
+
+Joystick::Joystick(SDL_Joystick *j)
+{
+    joy = j;
+}
+
+void
+Joystick::check(void)
+{
+    SDL_JoystickUpdate();
+
+    if (SDL_JoystickGetButton(joy,CROSS)==SDL_PRESSED) {
+	    cross.push_work();
+    } else {
+	cross.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,CIRCLE)==SDL_PRESSED) {
+	circle.push_work();
+    } else {
+	circle.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,SQUARE)==SDL_PRESSED) {
+	square.push_work();
+    } else {
+	square.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,TRIANGLE)==SDL_PRESSED) {
+	triangle.push_work();
+    } else {
+	triangle.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,L1)==SDL_PRESSED) {
+	l1.push_work();
+    } else {
+	l1.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,R1)==SDL_PRESSED) {
+	r1.push_work();
+    } else {
+	r1.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,L2)==SDL_PRESSED) {
+	l2.push_work();
+    } else {
+	l2.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,R2)==SDL_PRESSED) {
+	r2.push_work();
+    } else {
+	r2.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,START)==SDL_PRESSED) {
+	start.push_work();
+    } else {
+	start.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,SELECT)==SDL_PRESSED) {
+	select.push_work();
+    } else {
+	select.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,L3)==SDL_PRESSED) {
+	l3.push_work();
+    } else {
+	l3.release_work();
+    }
+
+    if (SDL_JoystickGetButton(joy,R3)==SDL_PRESSED) {
+	r3.push_work();
+    } else {
+	r3.release_work();
+    }
+
+    axis = SDL_JoystickGetAxis(joy,0);
+    if (axis >= 3200) {
+	left.release_work();
+	right.push_work();
+    } else if (axis <= -3200) {
+	right.release_work();
+	left.push_work();
+    } else {
+	left.release_work();
+	right.release_work();
+    }
+
+    axis = SDL_JoystickGetAxis(joy,1);
+    if (axis>=3200) {
+	up.release_work();
+	down.push_work();
+    } else if (axis<=-3200) {
+	down.release_work();
+	up.push_work();
+    } else {
+	up.release_work();
+	down.release_work();
+    }
+}
+
+void
+Joystick::close(void)
+{
+    SDL_JoystickClose(joy);
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TaskManager/Test/test_render/Joystick.h	Fri Nov 28 15:24:55 2008 +0900
@@ -0,0 +1,19 @@
+#ifndef INCLUDED_JOYSTICK
+#define INCLUDED_JOYSTICK
+
+#ifndef INCLUDED_PAD
+#  include "Pad.h"
+#endif
+
+class Joystick : public Pad {
+public:
+    SDL_Joystick *joy;
+    Sint16 axis;
+
+    Joystick(SDL_Joystick *j);
+
+    void check(void);
+    void close(void);
+};
+
+#endif
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TaskManager/Test/test_render/Keyboard.cpp	Fri Nov 28 15:24:55 2008 +0900
@@ -0,0 +1,68 @@
+#include <SDL.h>
+#include "Keyboard.h"
+
+void
+Keyboard::check(void)
+{
+    Uint8 *keys = SDL_GetKeyState(NULL);
+
+    if (keys[SDLK_UP] == SDL_PRESSED) {
+	up.push_work();
+    } else {
+	up.release_work();
+    }
+
+    if (keys[SDLK_DOWN] == SDL_PRESSED) {
+	down.push_work();
+    } else {
+	down.release_work();
+    }
+
+    if (keys[SDLK_RIGHT] == SDL_PRESSED) {
+	right.push_work();
+    } else {
+	right.release_work();
+    }
+
+    if (keys[SDLK_LEFT] == SDL_PRESSED) {
+	left.push_work();
+    } else {
+	left.release_work();
+    }
+
+    if (keys[SDLK_RETURN] == SDL_PRESSED) {
+	start.push_work();
+    } else {
+	start.release_work();
+    }
+
+    if (keys[SDLK_ESCAPE] == SDL_PRESSED) {
+	select.push_work();
+    } else {
+	select.release_work();
+    }
+
+    if (keys[SDLK_a] == SDL_PRESSED) {
+	square.push_work();
+    } else {
+	square.release_work();
+    }
+
+    if (keys[SDLK_s] == SDL_PRESSED) {
+	triangle.push_work();
+    } else {
+	triangle.release_work();
+    }
+
+    if (keys[SDLK_z] == SDL_PRESSED) {
+	cross.push_work();
+    } else {
+	cross.release_work();
+    }
+
+    if (keys[SDLK_x] == SDL_PRESSED) {
+	circle.push_work();
+    } else {
+	circle.release_work();
+    }
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TaskManager/Test/test_render/Keyboard.h	Fri Nov 28 15:24:55 2008 +0900
@@ -0,0 +1,13 @@
+#ifndef INCLUDED_KEYBOARD
+#define INCLUDED_KEYBOARD
+
+#ifndef INCLUDED_PAD
+#  include "Pad.h"
+#endif
+
+class Keyboard : public Pad {
+public:
+    void check(void);
+};
+
+#endif
--- a/TaskManager/Test/test_render/Makefile.def	Fri Nov 28 13:51:54 2008 +0900
+++ b/TaskManager/Test/test_render/Makefile.def	Fri Nov 28 15:24:55 2008 +0900
@@ -11,7 +11,7 @@
 #CERIUM = ../../..
 
 CC      = g++
-CFLAGS  = -O9 -g -Wall# -DDEBUG
+CFLAGS  = -O0 -g -Wall# -DDEBUG
 
 INCLUDE = -I$(CERIUM)/include/TaskManager -I.
 LIBS = -L$(CERIUM)/TaskManager
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TaskManager/Test/test_render/Pad.h	Fri Nov 28 15:24:55 2008 +0900
@@ -0,0 +1,35 @@
+#ifndef INCLUDED_PAD
+#define INCLUDED_PAD
+
+#ifndef INCLUDED_BUTTON
+#  include "Button.h"
+#endif
+
+class Pad {
+public:
+    Button count;
+    Button cross;
+    Button circle;
+    Button square;
+    Button triangle;
+    Button l1;
+    Button r1;
+    Button l2;
+    Button r2;
+    Button start;
+    Button select;
+    Button l3;
+    Button r3;
+    Button up;
+    Button down;
+    Button right;
+    Button left;
+    Button escape;
+    Button space;
+
+    virtual ~Pad(void) {}
+    virtual void check(void) = 0;
+    virtual void close(void) {}
+};
+
+#endif
--- a/TaskManager/Test/test_render/SceneGraph.cpp	Fri Nov 28 13:51:54 2008 +0900
+++ b/TaskManager/Test/test_render/SceneGraph.cpp	Fri Nov 28 15:24:55 2008 +0900
@@ -18,8 +18,19 @@
 no_collision(SceneGraphPtr self, int screen_w, int screen_h,
 	     SceneGraphPtr tree) {}
 
+SceneGraphPtr scene_graph = NULL;
+SceneGraphPtr scene_graph_viewer = NULL;
+
+
 SceneGraph::SceneGraph(void)
 {
+    init();
+}
+
+
+void
+SceneGraph::init(void)
+{
     next = NULL;
     last = NULL;
 
@@ -39,23 +50,10 @@
     collision = no_collision;
 }
 
-
 /* construct polygon from xmlNode.  */
 SceneGraph::SceneGraph(xmlNodePtr surface)
 {
-#if 1
-    next = NULL;
-    last = NULL;
-    parent = NULL;
-    brother = NULL;
-    children = NULL;
-    lastChild = NULL;
-    move = no_move;
-    collision = no_collision;
-#else
-    // こうしたいんだけどなー
-    this->SceneGraph();
-#endif
+    init();
 
     size = atoi((char *)xmlGetProp(surface,(xmlChar *)"size"));
     name = (char *)xmlGetProp(surface,(xmlChar *)"name");
@@ -66,15 +64,19 @@
     get_data(surface->children);
 }
 
+SceneGraph::~SceneGraph(void)
+{
+    delete [] data;
+}
 
 /* XMLファイルからポリゴンを作成  */
-SceneGraph*
+void
 SceneGraph::createFromXMLfile(char *xmlfile)
 {
     xmlDocPtr doc;
     xmlNodePtr cur;
-    SceneGraph *root = NULL, *tmp, *parent;
-
+    SceneGraphPtr root = NULL, tmp, parent;
+    
     /* パース DOM生成 */
     doc = xmlParseFile(xmlfile);
     cur = xmlDocGetRootElement(doc);
@@ -94,6 +96,7 @@
 	if ( tmp->parent_name==NULL || 0==strcmp(tmp->parent_name, "NULL")) {
 	    /* このsurfaceがroot  */
 	    root = tmp;
+	    scene_graph = tmp;
 	} else {
 	    /* 親はこのsurfaceより前に定義されているものとする (していい?)  */
 	    //  ここで parent_name を用いるのは間違っていて、
@@ -106,12 +109,15 @@
 	    } else {
 		parent->addChild(tmp);
 	    }
-	    root->add_next(tmp);
+
+	    scene_graph->add_next(tmp);
 	}
     }
   
     xmlFreeDoc(doc);
-    return root;
+
+    //return root;
+    scene_graph_viewer = root;
 }
 
 /* 子供を追加  */
@@ -313,18 +319,16 @@
 void
 SceneGraph::delete_data(void)
 {
-    SceneGraph *n,*m;
+    SceneGraphPtr n = this->next, m;
 
-    n = this;
-    delete [] n->data;
+    //n = this;
+    //delete [] n->data;
 
-    if (next)
-    {
-	for(n = this->next; n; n=m)
-	{
+    if (next) {
+	while (n) {
 	    m = n->next;
-	    delete [] n->data;
 	    delete n;
+	    n = m;
 	}
     }
 }
@@ -405,25 +409,6 @@
 SceneGraph::clone(void) {
     SceneGraphPtr p = new SceneGraph;
     memcpy(p, this, sizeof(SceneGraph));
-
-
-    // どっかで関数にまとめるか
-    p->next = NULL;
-    p->last = NULL;
-
-    p->parent = NULL;
-    p->brother = NULL;
-    p->children = NULL;
-    p->lastChild = NULL;
-    p->move = no_move;
-    p->collision = no_collision;
-
-    p->stack_xyz[0] = 0.0f;
-    p->stack_xyz[2] = 0.0f;
-    p->stack_xyz[1] = 0.0f;
-    p->stack_angle[0] = 0.0f;
-    p->stack_angle[1] = 0.0f;
-    p->stack_angle[2] = 0.0f;
-    
+    p->init();
     return p;
 }
--- a/TaskManager/Test/test_render/SceneGraph.h	Fri Nov 28 13:51:54 2008 +0900
+++ b/TaskManager/Test/test_render/SceneGraph.h	Fri Nov 28 15:24:55 2008 +0900
@@ -5,6 +5,10 @@
 #  include "polygon.h"
 #endif
 
+#ifndef INCLUDED_PAD
+#  include "Pad.h"
+#endif
+
 class SceneGraph;
 
 typedef void (*move_func)(SceneGraph* node, int screen_w, int screen_h);
@@ -16,6 +20,7 @@
 public:
     SceneGraph(void);
     SceneGraph(xmlNodePtr surface);
+    ~SceneGraph(void);
 
     // Node がもつ状態変数(というべきか否か
     // xyz,angle ぐらいあればおk?
@@ -32,10 +37,13 @@
     SceneGraph *children;
     SceneGraph *lastChild;
 
+    Pad *controller;
+
     // 関数ポインタ
     move_func move;
     collision_func collision;
 
+    void init(void);
     void move_execute(int screen_w, int screen_h);
     void collision_check(int screen_w, int screen_h, SceneGraph *tree);
     void all_execute(int screen_w, int screen_h);
@@ -49,7 +57,7 @@
 			    move_func new_move, collision_func new_collision);
 
 
-    static SceneGraph* createFromXMLfile(char *);
+    static void createFromXMLfile(char *);
 
     void tree_check(void);
     void print_member(void);
@@ -59,4 +67,8 @@
 
 #endif
 
+// オリジナル (Linked List)
 extern SceneGraphPtr scene_graph;
+
+// 描画用 (同じオブジェクトが複数ある) Tree
+extern SceneGraphPtr scene_graph_view;
--- a/TaskManager/Test/test_render/node.cpp	Fri Nov 28 13:51:54 2008 +0900
+++ b/TaskManager/Test/test_render/node.cpp	Fri Nov 28 15:24:55 2008 +0900
@@ -88,6 +88,7 @@
     node->xyz[1] += node->stack_xyz[1];
     if ((int)node->xyz[1] > screen_h || (int)node->xyz[1] < 0) {
 
+	// 実は微妙に意味が無い
 	srandom(random());
 
 	SceneGraphPtr p = node->clone();
@@ -108,9 +109,8 @@
 node_init(void)
 {
 #if 0
-    //scene_graph->set_move_collision(Earth, earth_move, earth_collision);
-    //scene_graph->set_move_collision(Moon, moon_move, moon_collision);
-    //scene_graph->set_move_collision(Plain, cube_move, cube_collision);
+    scene_graph->set_move_collision(Earth, earth_move, earth_collision);
+    scene_graph->set_move_collision(Moon, moon_move, moon_collision);
 #else
     scene_graph->set_move_collision(Cube, cube_move, cube_collision);
     Cube->stack_xyz[0] = 2.0f;
--- a/TaskManager/Test/test_render/pad.h	Fri Nov 28 13:51:54 2008 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,18 +0,0 @@
-const int CROSS = 0;
-const int CIRCLE = 1;
-const int SQUARE = 2;
-const int TRIANGLE = 3;
-const int L1 = 4;
-const int R1 = 5;
-const int L2 = 6;
-const int R2 = 7;
-const int START = 8;
-const int SELECT = 9;
-const int L3 = 10;
-const int R3 = 11;
-const int UP = 12;
-const int DOWN = 13;
-const int RIGHT = 14;
-const int LEFT = 15;
-
-int pad(int button);
--- a/TaskManager/Test/test_render/viewer.cpp	Fri Nov 28 13:51:54 2008 +0900
+++ b/TaskManager/Test/test_render/viewer.cpp	Fri Nov 28 15:24:55 2008 +0900
@@ -1,3 +1,4 @@
+#include <SDL.h>
 #include "viewer.h"
 #include "viewer_types.h"
 #include "SceneGraph.h"
@@ -6,6 +7,8 @@
 #include "Func.h"
 #include "error.h"
 #include "TaskManager.h"
+#include "Keyboard.h"
+#include "Joystick.h"
 
 extern void post2runLoop(void *);
 extern void post2runDraw(void *);
@@ -15,7 +18,8 @@
 int this_time;
 int frames;
 
-SceneGraph *scene_graph;
+extern SceneGraphPtr scene_graph;
+extern SceneGraphPtr scene_graph_viewer;
 
 /* Data Pack */
 SceneGraphPack *sgpack;
@@ -27,6 +31,30 @@
 
 void *__texture;
 
+
+/**
+ * Joystick があればそれを使い、
+ * 無ければキーボードを返す
+ */
+static Pad*
+create_controller(void)
+{
+    if (SDL_NumJoysticks()) {
+	SDL_Joystick *joy = SDL_JoystickOpen(0);
+	if (!joy) {
+	    fprintf(stderr, "%s: failed to open joystick", __FUNCTION__);
+	    return new Keyboard;
+	} else {
+	    printf("Use Joystick\n");
+	    return new Joystick(joy);
+	}
+    } else {
+	printf("Use Keyboard\n");
+	return new Keyboard;
+    }
+}
+
+
 Viewer::Viewer(int b, int w, int h, int _num)
 {
     bpp = b;
@@ -87,8 +115,16 @@
     this_time  = 0;
     frames     = 0;
 
-    scene_graph = SceneGraph::createFromXMLfile(xml);
+    //scene_graph = SceneGraph::createFromXMLfile(xml);
+    /**
+     * これを実行すると、
+     * scene_graph にオリジナルの SceneGraph Object のリストが、
+     * scene_graph_viewer に描画用の SceneGraph が生成される
+     */
+    SceneGraph::createFromXMLfile(xml);
     //polygon->viewer  = this;
+
+    scene_graph->controller = create_controller();
 	
     node_init();
 
@@ -210,7 +246,8 @@
     task_next->wait_for(task_update_sgp);
     task_update_sgp->spawn();
 #else
-    scene_graph->all_execute(width, height);
+    scene_graph->controller->check();
+    scene_graph_viewer->all_execute(width, height);
 #endif
 
 #if 0
@@ -219,7 +256,7 @@
     task_create_pp->add_param((uint32)ppack);
 #else
     task_create_pp = manager->create_task(TASK_CREATE_PP2);
-    task_create_pp->add_param((uint32)scene_graph);
+    task_create_pp->add_param((uint32)scene_graph_viewer);
     task_create_pp->add_param((uint32)ppack);
 #endif
     task_next->wait_for(task_create_pp);
@@ -331,6 +368,7 @@
     }
 
     scene_graph->delete_data();
+    scene_graph->controller->close();
     delete scene_graph;
 
     free(__texture);