Mercurial > hg > Members > kono > tree_dandy2
changeset 19:bdc882acda58
get_matrix
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Thu, 09 Dec 2010 22:31:06 +0900 |
parents | 7e7e6f73b11f |
children | 095e9575cc0a |
files | Dandy.cc |
diffstat | 1 files changed, 17 insertions(+), 19 deletions(-) [+] |
line wrap: on
line diff
--- a/Dandy.cc Wed Dec 08 18:36:52 2010 +0900 +++ b/Dandy.cc Thu Dec 09 22:31:06 2010 +0900 @@ -26,7 +26,7 @@ #include "LoadSprite.h" #include <SDL_mixer.h> #include "error.h" -#include "sys.h" +#include "matrix_calc.h" #include "Character.h" #include "Character_state.h" @@ -151,6 +151,13 @@ LightSysSwitch(Viewer *sgroot) { if (light_sysswitch == 1) { sgroot->OnLightSysSwitch(); + for (int i = 0; i < light_num; i++) { + SceneGraphPtr light = sgroot->getLight(i); + sgroot->OnLightSwitch(i); + light->xyz[0] = screen_w / 2; + light->xyz[1] = screen_h / 2; + light->xyz[2] = -100; + } } else if (light_sysswitch == 0) { sgroot->OffLightSysSwitch(); } @@ -174,13 +181,6 @@ sgroot->createFromXMLfile("xml/boss.xml"); LightSysSwitch(sgroot); - for (int i = 0; i < light_num; i++) { - SceneGraphPtr light = sgroot->getLight(i); - sgroot->OnLightSwitch(i); - light->xyz[0] = screen_w / 2; - light->xyz[1] = screen_h / 2; - light->xyz[2] = -100; - } init_sprite(0,0,0,0); @@ -231,9 +231,7 @@ SceneGraphPtr root; -extern void get_matrix(float *matrix, float *rxyz, float *txyz, float *stack); -extern void ScaleMatrix(float *matrix, float rxyz); -extern void ScaleMatrixXY(float *matrix, float x, float y); +// extern void get_matrix(float *matrix, float *rxyz, float *txyz, float *scale, float *stack); static void flip() @@ -249,9 +247,9 @@ root->xyz[2] = 30.0f; /*親の回転、座標から、子の回転、座標を算出*/ - get_matrix(root->matrix, root->angle, root->xyz, camera->matrix); + get_matrix(root->matrix, root->angle, root->xyz, root->scale, camera->matrix); /*法線用の行列。Cameraの行列を抜いている(Cameraのコンストラクタで、単位行列にしている)*/ - get_matrix(root->real_matrix, root->angle, root->xyz, camera->real_matrix); + get_matrix(root->real_matrix, root->angle, root->xyz, root->scale, camera->real_matrix); sgroot->setSceneData(root); } @@ -560,11 +558,11 @@ object->xyz[2] = 0; root->addChild(object); + float scale[] = {5,5,1}; /*親の回転、座標から、子の回転、座標を算出*/ - get_matrix(object->matrix, object->angle, object->xyz, root->matrix); - ScaleMatrixXY(object->matrix,5,5); + get_matrix(object->matrix, object->angle, object->xyz, scale, root->matrix); /*法線用の行列。Cameraの行列を抜いている(Cameraのコンストラクタで、単位行列にしている)*/ - get_matrix(object->real_matrix, object->angle, object->xyz, root->real_matrix); + get_matrix(object->real_matrix, object->angle, object->xyz, scale, root->real_matrix); } @@ -586,11 +584,11 @@ object->angle[3] = angle; root->addChild(object); + float scale[] = {5*scalex,5*scaley,1}; /*親の回転、座標から、子の回転、座標を算出*/ - get_matrix(object->matrix, object->angle, object->xyz, root->matrix); - ScaleMatrixXY(object->matrix,scalex*5,scaley*5); + get_matrix(object->matrix, object->angle, object->xyz, scale, root->matrix); /*法線用の行列。Cameraの行列を抜いている(Cameraのコンストラクタで、単位行列にしている)*/ - get_matrix(object->real_matrix, object->angle, object->xyz, root->real_matrix); + get_matrix(object->real_matrix, object->angle, object->xyz, scale, root->real_matrix); }