changeset 597:1bfa45a08fa7 draft

add Light Object
author yutaka@henri.cr.ie.u-ryukyu.ac.jp
date Thu, 05 Nov 2009 20:17:59 +0900
parents f1c2e11a2ef4
children 7c051c101642
files Renderer/Engine/Light.cc Renderer/Engine/Light.h Renderer/Engine/SceneGraphRoot.cc Renderer/Engine/SceneGraphRoot.h Renderer/Engine/task/CreatePolygonFromSceneGraph.cc
diffstat 5 files changed, 71 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Renderer/Engine/Light.cc	Thu Nov 05 20:17:59 2009 +0900
@@ -0,0 +1,42 @@
+#include <math.h>
+#include "SceneGraphRoot.h"
+#include "Light.h"
+#include "sys.h"
+#include "Scheduler.h"
+#include "show_time.h"
+#include "TaskManager.h"
+
+static void
+light_move(SceneGraphPtr node, int screen_w, int screen_h)
+{
+
+}
+
+static void
+light_collision(SceneGraphPtr node, int screen_w, int screen_h,
+		 SceneGraphPtr tree)
+{
+}
+
+/**
+ * @param w Width of screen
+ * @param h Height of screen
+ */
+Light::Light(float w, float h)
+{
+    name = (char*)"Light";
+
+    // Screen の真ん中を初期値とする
+    xyz[0] = w/2.0f;
+    xyz[1] = h/2.0f;
+    xyz[2] = 0;
+    xyz[3] = 1.0f;
+
+    this->set_move_collision(light_move, light_collision);
+}
+
+Light::~Light(void)
+{
+
+}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Renderer/Engine/Light.h	Thu Nov 05 20:17:59 2009 +0900
@@ -0,0 +1,13 @@
+#ifndef INCLUDED_LIGHT
+#define INCLUDED_LIGHT
+#include "SceneGraph.h"
+
+class Light : public SceneGraph {
+public:
+  Light(float w, float h);
+  ~Light(void);
+};
+
+typedef Light *LightPtr;
+
+#endif
--- a/Renderer/Engine/SceneGraphRoot.cc	Wed Nov 04 22:52:06 2009 +0900
+++ b/Renderer/Engine/SceneGraphRoot.cc	Thu Nov 05 20:17:59 2009 +0900
@@ -25,6 +25,7 @@
     sg_src = (SceneGraphPtr*) malloc(sizeof(SceneGraphPtr)*SGLIST_LENGTH);
 
     camera = new Camera(w, h);
+    light = new Light(w, h);
     iterator = new SceneGraphIterator;
     controller = create_controller();
 
@@ -63,6 +64,7 @@
 
     free(sg_src);
     delete camera;
+    delete light;
     delete iterator;
     delete controller;
 }
@@ -527,3 +529,11 @@
 {
     return camera;
 }
+
+LightPtr
+SceneGraphRoot::getLight()
+{
+
+  return light;
+
+}
--- a/Renderer/Engine/SceneGraphRoot.h	Wed Nov 04 22:52:06 2009 +0900
+++ b/Renderer/Engine/SceneGraphRoot.h	Thu Nov 05 20:17:59 2009 +0900
@@ -4,6 +4,7 @@
 #include "SceneGraph.h"
 #include "SceneGraphArray.h"
 #include "Camera.h"
+#include "Light.h"
 #include "SceneGraphIterator.h"
 #include <sys/types.h>
 
@@ -51,6 +52,9 @@
     // カメラオブジェクト
     Camera *camera;
 
+    // 光源のオブジェクト
+    Light *light;
+
     // SceneGraphIterator
     SceneGraphIteratorPtr iterator;
 
@@ -73,6 +77,7 @@
     SceneGraphIteratorPtr getIterator();
     SceneGraphIteratorPtr getIterator(SceneGraphPtr list);
     CameraPtr getCamera();
+    LightPtr getLight();
 
     /* Other System API */
     void allExecute(int screen_w, int screen_h);
--- a/Renderer/Engine/task/CreatePolygonFromSceneGraph.cc	Wed Nov 04 22:52:06 2009 +0900
+++ b/Renderer/Engine/task/CreatePolygonFromSceneGraph.cc	Thu Nov 05 20:17:59 2009 +0900
@@ -171,7 +171,6 @@
 		triangle->ver3.tex_x = sg->coord_tex[(i+2)*3];
 		triangle->ver3.tex_y = sg->coord_tex[(i+2)*3+1];
 
-                //法線もApplyMatrixとかするのかな?一応値をとっておくby yutaka
 
                 normal1[0] = sg->normal[(i+0)*3];
                 normal1[1] = sg->normal[(i+0)*3+1];
@@ -190,7 +189,7 @@
 
                 ApplyNormalMatrix(normal1,sg->matrix);
 
-                //ここでpolygonに法線ベクトルの情報がわたったby yutaka
+                //ここでpolygonに法線ベクトルの情報がわたった
 
                 triangle->normal1.x = normal1[0];
                 triangle->normal1.y = normal1[1];