Mercurial > hg > old > magoroku_racing
changeset 99:c534f339ee8b
change c++
author | e085768 |
---|---|
date | Thu, 02 Jun 2011 17:51:41 +0900 |
parents | 1033fece71ce |
children | e5f2eb98b575 |
files | Makefile a.out camera.c camera.cc car.c car.cc carNode.c carNode.cc col.c col.cc controler.c controler.cc field.c field.cc gFont.c gFont.cc gSprite.c gSprite.cc game.c game.cc game_time.c game_time.cc hikae light.c light.cc linda.cc main.c main.cc mytype.c mytype.cc ps2util.c ps2util.cc quotanion.c quotanion.cc schedule.c schedule.cc schedule.h sjoy.c sjoy.cc test_vector test_vector.cc title_scene.c title_scene.cc |
diffstat | 43 files changed, 3723 insertions(+), 2785 deletions(-) [+] |
line wrap: on
line diff
--- a/Makefile Thu Jun 02 17:26:21 2011 +0900 +++ b/Makefile Thu Jun 02 17:51:41 2011 +0900 @@ -1,8 +1,8 @@ TARGET = main -CC = gcc -SRCS = main.c game.c car.c col.c quotanion.c controler.c field.c camera.c gSprite.c schedule.c mytype.c gFont.c carNode.c light.c title_scene.c game_time.c ps2util.c sjoy.c -#linda/lindaapi.c linda.c -OBJS = ${SRCS:.c=.o} +CC = g++ +SRCS = main.cc game.cc car.cc col.cc quotanion.cc controler.cc field.cc camera.cc gSprite.cc schedule.cc mytype.cc gFont.cc carNode.cc light.cc title_scene.cc game_time.cc ps2util.cc sjoy.cc +#linda/lindaapi.cc linda.c +OBJS = ${SRCS:.cc=.o} VU1DIR = vu1code #MPGOBJ = mpg.elf @@ -41,7 +41,7 @@ ${TARGET} : ${OBJS} ${CC} -o ${TARGET} ${OBJS} -${TEST} : test_vector.c ps2util.c +${TEST} : test_vector.cc ps2util.cc ${CC} -o ${TEST} $^ tag:
--- a/camera.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,105 +0,0 @@ -#include <stdlib.h> -#include <string.h> -#include "libps2.h" -#include "ps2util.h" -#include "car.h" -#include "game.h" -#include "controler.h" -#include "camera.h" - -//大域変数、各部で共有 -extern SGO_PAD pad; - -static CAMERA camera, def_camera; - - -void -camera_init() -{ - - //カメラの初期位置設定 - def_camera.xyz[0] = 0; - def_camera.xyz[1] =-7;// -3; - def_camera.xyz[2] =-14; //0; - def_camera.xyz[3] = 1; - - def_camera.zd[0] = 0; - def_camera.zd[1] = 2; - def_camera.zd[2] = 7; - def_camera.zd[3] = 1; - - def_camera.yd[0] = 0; - def_camera.yd[1] = 1; - def_camera.yd[2] = 0; - def_camera.yd[3] = 1; - - def_camera.angle[0]=-0.2;//0; //pich - def_camera.angle[1]=0; //yoh - def_camera.angle[2]=0; //roll - def_camera.angle[3]=0; - - //def_cameraをcameraにコピー - memcpy( &camera, &def_camera, sizeof(CAMERA)); - set_camera(&def_camera); - -} - -/* - ps2依存関係から拝借。 - 自分が消したのか、元々無いのかは覚えていないけど - 呼ばれているのでとりあえず(空っぽにしておく)。 -*/ -// set_camera must be called if camera's parameters were moved -void set_camera(CAMERA *camera) -{ - //vu0_rot_camera_matrix(world_view, camera->xyz, camera->zd, camera->yd,camera->angle); -} - - -/** - * pose: カメラの対象物(obj)の座標行列 - * カメラがobjについていくように(そのような動きに見せるため) - * カメラの位置ベクトル、視点ベクトルを更新 - */ -void -camera_update(Game *game, FMATRIX pose) -{ - FVECTOR location, eyes, vertical, angle; - - //int type = game->camera_type; - - ps2_vu0_apply_matrix(location, pose, def_camera.xyz); - ps2_vu0_apply_matrix(eyes, pose, def_camera.zd); - ps2_vu0_apply_matrix(vertical, pose, def_camera.yd); - - /**When the car bends, the angle of the camera is changed**/ - if(pad.left>0 && game->jiki->speed !=0){ - if(game->jiki->speed !=0){ - if(def_camera.angle[1]<=0.2){ - def_camera.angle[1]+=0.02; - } - } - } - else if(pad.right>0 && game->jiki->speed !=0){ - if(game->jiki->speed !=0){ - if(def_camera.angle[1]>=-0.2){ - def_camera.angle[1]-=0.02; - } - } - } - else { - if(def_camera.angle[1]<-0.01){ - def_camera.angle[1]+=0.02; - } - else if(def_camera.angle[1]>0.01){ - def_camera.angle[1]-=0.02; - } - } - ps2_vu0_apply_matrix(angle, pose, def_camera.angle); - ps2_vu0_copy_vector(camera.xyz, location); - ps2_vu0_copy_vector(camera.zd, eyes); - ps2_vu0_copy_vector(camera.yd, vertical); - ps2_vu0_copy_vector(camera.angle, angle); - set_camera(&camera); - -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/camera.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,105 @@ +#include <stdlib.h> +#include <string.h> +#include "libps2.h" +#include "ps2util.h" +#include "car.h" +#include "game.h" +#include "controler.h" +#include "camera.h" + +//大域変数、各部で共有 +extern SGO_PAD pad; + +static CAMERA camera, def_camera; + + +void +camera_init() +{ + + //カメラの初期位置設定 + def_camera.xyz[0] = 0; + def_camera.xyz[1] =-7;// -3; + def_camera.xyz[2] =-14; //0; + def_camera.xyz[3] = 1; + + def_camera.zd[0] = 0; + def_camera.zd[1] = 2; + def_camera.zd[2] = 7; + def_camera.zd[3] = 1; + + def_camera.yd[0] = 0; + def_camera.yd[1] = 1; + def_camera.yd[2] = 0; + def_camera.yd[3] = 1; + + def_camera.angle[0]=-0.2;//0; //pich + def_camera.angle[1]=0; //yoh + def_camera.angle[2]=0; //roll + def_camera.angle[3]=0; + + //def_cameraをcameraにコピー + memcpy( &camera, &def_camera, sizeof(CAMERA)); + set_camera(&def_camera); + +} + +/* + ps2依存関係から拝借。 + 自分が消したのか、元々無いのかは覚えていないけど + 呼ばれているのでとりあえず(空っぽにしておく)。 +*/ +// set_camera must be called if camera's parameters were moved +void set_camera(CAMERA *camera) +{ + //vu0_rot_camera_matrix(world_view, camera->xyz, camera->zd, camera->yd,camera->angle); +} + + +/** + * pose: カメラの対象物(obj)の座標行列 + * カメラがobjについていくように(そのような動きに見せるため) + * カメラの位置ベクトル、視点ベクトルを更新 + */ +void +camera_update(Game *game, FMATRIX pose) +{ + FVECTOR location, eyes, vertical, angle; + + //int type = game->camera_type; + + ps2_vu0_apply_matrix(location, pose, def_camera.xyz); + ps2_vu0_apply_matrix(eyes, pose, def_camera.zd); + ps2_vu0_apply_matrix(vertical, pose, def_camera.yd); + + /**When the car bends, the angle of the camera is changed**/ + if(pad.left>0 && game->jiki->speed !=0){ + if(game->jiki->speed !=0){ + if(def_camera.angle[1]<=0.2){ + def_camera.angle[1]+=0.02; + } + } + } + else if(pad.right>0 && game->jiki->speed !=0){ + if(game->jiki->speed !=0){ + if(def_camera.angle[1]>=-0.2){ + def_camera.angle[1]-=0.02; + } + } + } + else { + if(def_camera.angle[1]<-0.01){ + def_camera.angle[1]+=0.02; + } + else if(def_camera.angle[1]>0.01){ + def_camera.angle[1]-=0.02; + } + } + ps2_vu0_apply_matrix(angle, pose, def_camera.angle); + ps2_vu0_copy_vector(camera.xyz, location); + ps2_vu0_copy_vector(camera.zd, eyes); + ps2_vu0_copy_vector(camera.yd, vertical); + ps2_vu0_copy_vector(camera.angle, angle); + set_camera(&camera); + +}
--- a/car.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,299 +0,0 @@ -/* car.c */ - -#include <stdio.h> -#include <stdlib.h> -#include <stdbool.h> -#include "libps2.h" -#include "ps2util.h" -#include "field.h" -#include "car.h" -#include "mytype.h" -#include "quotanion.h" -#include "game.h" -#include "stdbool.h" - -#define DEFAULT_SET (EFFECT_TEXTURE_USE | EFFECT_ALPHABLEND_UNUSE | EFFECT_SHADING_FLAT) -#define BUFSIZE 256 - -/* 初期位置と初期方向 */ -static FVECTOR location = {0, 0, 0, 1}; -static FVECTOR direction = {0, 0, 1, 1}; - -extern FILE* main_fp; - -static CarPtr -car_create(int car_id, char *filename, char *texname, float speed_accel, - float speed_max, float rot, float brake) -{ - CarPtr car; - OBJECT *body; - TEXTURE* tex; - void *free_addr; - - body = ps2util_obj_Create_fromXML(filename); - ps2util_obj_Set_effect(body, DEFAULT_SET); - - if (malloc_align16(&free_addr, &car, sizeof(Car)) == -1) { - fprintf(main_fp, "car.c: malloc_align16 error\n"); - exit(EXIT_FAILURE); - } - car->body = body; - car->next = NULL; - car->speed = 0.0; - car->speed_accel = speed_accel; - car->speed_max = speed_max; - car->brake = brake; - car->rotation_angle = rot; - car->y_angle = 0.0; - car->free_addr = free_addr; - - ps2_vu0_copy_vector(car->direction, direction); - ps2_vu0_copy_vector(car->location, location); - INIT_VECTOR(car->vertical, 0, -1, 0, 1); - INIT_VECTOR(car->body->xyz, 0, 0, 0, 1); - INIT_VECTOR(car->body->angle, 0, 0, 0, 1); - - ps2util_obj_Renew_transMatrix(car->body); - ps2util_obj_Set_effect(car->body, DEFAULT_SET); - - if (*texname != 'n') { - tex = read_png_file(texname); - ps2util_tex_Set(tex); - ps2util_obj_Set_texture(car->body, tex); - } - -#ifdef DEBUG - fprintf(main_fp, "malloc car addr = %x\n", (int)free_addr); -#endif - - return car; -} - -static CarPtr -car_new_readCSV(FILE *fp, int id) -{ - CarPtr new; - int car_id; - float speed_accel, speed_max, brake, rot; - char buff[BUFSIZE], *bufp; - char carImg[BUFSIZE], texImg[BUFSIZE]; - bool flag; - - flag = false; - - while ((bufp = fgets(buff, BUFSIZE, fp)) != NULL) { - bufp++; - - switch (buff[0]) { - case 'n': - if (flag == false) { - sscanf(bufp, " %d\n", &car_id); - if (id == car_id) { - flag = true; - } - } - break; - case 't': - if (flag == true) { - sscanf(bufp, " %s %s %f %f %f %f\n", - carImg, texImg, &speed_accel, &speed_max, &rot, &brake); - new = car_create(id, carImg, texImg, - speed_accel, speed_max, rot, brake); - return new; - } - break; - default: - break; - } - } - - /* ここまで辿り着いたら読み込み失敗 */ - fprintf(main_fp, "error - car_new_readCSV\n"); - exit(EXIT_FAILURE); -} - -CarPtr car_init(int id) -{ - CarPtr new; - FILE *fp; - char *filename = "car/car.dat"; - - if (!(fp = fopen(filename, "r"))) { - fprintf(main_fp, "error read file %s\n", filename); - exit(EXIT_FAILURE); - } - new = car_new_readCSV(fp, id); - fclose(fp); - - return new; -} - -/*--------------------------- - carをY軸で回転させる - flg: 回転方向 1:右, -1:左 - ---------------------------*/ -void -car_swerve(CarPtr car, int flg) -{ - FMATRIX rot; - FVECTOR v; - - car->y_angle += (float)flg*car->rotation_angle; - car->y_angle += (car->y_angle < 0) ? 360.0 : 0; - car->y_angle += (car->y_angle > 360.0) ? -360.0 : 0; - - ps2_vu0_unit_matrix(rot); - ps2_vu0_rot_matrix_y(rot, rot, degree2radian((float)flg*car->rotation_angle)); - ps2_vu0_copy_vector(v, car->direction); - ps2_vu0_apply_matrix(car->direction, rot, v); -} - -/*---------------------------- - carを加速・減速する - (flg == 1) ? 加速 : 減速 - ---------------------------*/ -void -car_accelerate(CarPtr car, int flg) -{ - car->speed += (flg == 1) ? car->speed_accel : -car->brake; - car->speed = (car->speed < 0) ? 0 : car->speed; - car->speed = (car->speed > car->speed_max) ? car->speed_max : car->speed; -} - - -/*--------------------------------- - 進行後のcarに対してコース面の内外判定を行い、 - : 現在のコース - : 現在のコースの次のコース - : 現在のコースの前のコース - に存在すればTRUEを返す - どのコースにも居ない(壁に衝突した)場合は - FALSEを返す。 - ---------------------------------*/ -static bool -car_field_check(Game *game ,CarPtr car) -{ - FieldPtr p; - FieldPtr f = field_get_actual(); - - // 現在のコースで衝突・内外判定 - p = f; - if (col_detect(&p->colface, car->vertical, car->location) == true) { - goto FIELD_CHECK_OK; - } - - // 現在のコースの次に隣接するコースで衝突・内外判定 - p = f->next; - if (col_detect(&p->colface, car->vertical, car->location) == true) { - if (field_rap_increment(1)) { - game->rap++; - } - goto FIELD_CHECK_OK; - } - - // 現在のコースの前に隣接するコースで衝突・内外判定 - p = f->prev; - if (col_detect(&p->colface, car->vertical, car->location) == true) { - field_rap_increment(-1); - goto FIELD_CHECK_OK; - } - - // どのコース上にも居ない(壁に衝突) - return false; - - FIELD_CHECK_OK: - field_set_actual(p); - return true; -} - - -/*------------------------------ - 速度speedと向きdirectionから - 進行後の位置locationを求める。 - また、進行後の衝突判定も行う。 - ------------------------------*/ -static void -car_move(Game *game,CarPtr car) -{ - FVECTOR mov, prev_location; - - ps2_vu0_scale_vector(mov, car->direction, car->speed); - ps2_vu0_copy_vector(prev_location, car->location); - ps2_vu0_add_vector(car->location, car->location, mov); - - if (car_field_check(game,car) == false) { - ps2_vu0_copy_vector(car->location, prev_location); - car->speed = car->speed*0.5; - } -} - - -static void -car_axis_rotation(CarPtr car) -{ - FMATRIX pose, yrot, yrotinv; - - ps2_vu0_unit_matrix(yrot); - ps2_vu0_rot_matrix_y(yrot, yrot, -degree2radian(car->y_angle)); - ps2_vu0_unit_matrix(yrotinv); - ps2_vu0_rot_matrix_y(yrotinv, yrotinv, degree2radian(car->y_angle)); - - { - FVECTOR yd = {0, -1, 0, 1}; - FVECTOR rotaxis; - FVECTOR q; - - ps2_vu0_outer_product(rotaxis, car->vertical, yd); - { - float scale=1/NORM(rotaxis); - rotaxis[0] *= scale; - rotaxis[1] *= scale; - rotaxis[2] *= scale; - } - - quotanion(q, rotaxis, acos(ps2_vu0_inner_product(yd, car->vertical)/(NORM(yd)*NORM(car->vertical)))); - quotanion_rotmatrix(pose, q); - } - - ps2_vu0_mul_matrix(pose, yrot, pose); - ps2_vu0_mul_matrix(pose, pose, yrotinv); - ps2_vu0_copy_matrix(car->body->transfer, pose); - ps2_vu0_rot_matrix_y(car->body->transfer, car->body->transfer, degree2radian(car->y_angle)); -} - -void car_update( Game *game, CarPtr car ) -{ - // 移動 - car_move(game,car); - - // 摩擦による速度減少 - car->speed -= 0.005; - car->speed = (car->speed < 0) ? 0 : car->speed; - - // 傾き - car_axis_rotation(car); -} - - -void -car_destroy(CarPtr p) -{ - TEXTURE *t; - - if ((t = p->body->surfaces->texture)) { - ps2util_tex_Exclude(t); - free_texture(t); - } - ps2util_obj_Free(p->body); - free(p->free_addr); - -#ifdef DEBUG - fprintf(main_fp, "free car addr = %x\n", (int)p->free_addr); -#endif -} - -// 適当に自作 -void car_id_update(Game *game, CarPtr jiki) -{ - printf("car_id_update\n"); -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/car.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,299 @@ +/* car.c */ + +#include <stdio.h> +#include <stdlib.h> +#include <stdbool.h> +#include "libps2.h" +#include "ps2util.h" +#include "field.h" +#include "car.h" +#include "mytype.h" +#include "quotanion.h" +#include "game.h" +#include "stdbool.h" + +#define DEFAULT_SET (EFFECT_TEXTURE_USE | EFFECT_ALPHABLEND_UNUSE | EFFECT_SHADING_FLAT) +#define BUFSIZE 256 + +/* 初期位置と初期方向 */ +static FVECTOR location = {0, 0, 0, 1}; +static FVECTOR direction = {0, 0, 1, 1}; + +extern FILE* main_fp; + +static CarPtr +car_create(int car_id, char *filename, char *texname, float speed_accel, + float speed_max, float rot, float brake) +{ + CarPtr car; + OBJECT *body; + TEXTURE* tex; + void *free_addr; + + body = ps2util_obj_Create_fromXML(filename); + ps2util_obj_Set_effect(body, DEFAULT_SET); + + if (malloc_align16(&free_addr, &car, sizeof(Car)) == -1) { + fprintf(main_fp, "car.c: malloc_align16 error\n"); + exit(EXIT_FAILURE); + } + car->body = body; + car->next = NULL; + car->speed = 0.0; + car->speed_accel = speed_accel; + car->speed_max = speed_max; + car->brake = brake; + car->rotation_angle = rot; + car->y_angle = 0.0; + car->free_addr = free_addr; + + ps2_vu0_copy_vector(car->direction, direction); + ps2_vu0_copy_vector(car->location, location); + INIT_VECTOR(car->vertical, 0, -1, 0, 1); + INIT_VECTOR(car->body->xyz, 0, 0, 0, 1); + INIT_VECTOR(car->body->angle, 0, 0, 0, 1); + + ps2util_obj_Renew_transMatrix(car->body); + ps2util_obj_Set_effect(car->body, DEFAULT_SET); + + if (*texname != 'n') { + tex = read_png_file(texname); + ps2util_tex_Set(tex); + ps2util_obj_Set_texture(car->body, tex); + } + +#ifdef DEBUG + fprintf(main_fp, "malloc car addr = %x\n", (int)free_addr); +#endif + + return car; +} + +static CarPtr +car_new_readCSV(FILE *fp, int id) +{ + CarPtr new; + int car_id; + float speed_accel, speed_max, brake, rot; + char buff[BUFSIZE], *bufp; + char carImg[BUFSIZE], texImg[BUFSIZE]; + bool flag; + + flag = false; + + while ((bufp = fgets(buff, BUFSIZE, fp)) != NULL) { + bufp++; + + switch (buff[0]) { + case 'n': + if (flag == false) { + sscanf(bufp, " %d\n", &car_id); + if (id == car_id) { + flag = true; + } + } + break; + case 't': + if (flag == true) { + sscanf(bufp, " %s %s %f %f %f %f\n", + carImg, texImg, &speed_accel, &speed_max, &rot, &brake); + new = car_create(id, carImg, texImg, + speed_accel, speed_max, rot, brake); + return new; + } + break; + default: + break; + } + } + + /* ここまで辿り着いたら読み込み失敗 */ + fprintf(main_fp, "error - car_new_readCSV\n"); + exit(EXIT_FAILURE); +} + +CarPtr car_init(int id) +{ + CarPtr new; + FILE *fp; + char *filename = "car/car.dat"; + + if (!(fp = fopen(filename, "r"))) { + fprintf(main_fp, "error read file %s\n", filename); + exit(EXIT_FAILURE); + } + new = car_new_readCSV(fp, id); + fclose(fp); + + return new; +} + +/*--------------------------- + carをY軸で回転させる + flg: 回転方向 1:右, -1:左 + ---------------------------*/ +void +car_swerve(CarPtr car, int flg) +{ + FMATRIX rot; + FVECTOR v; + + car->y_angle += (float)flg*car->rotation_angle; + car->y_angle += (car->y_angle < 0) ? 360.0 : 0; + car->y_angle += (car->y_angle > 360.0) ? -360.0 : 0; + + ps2_vu0_unit_matrix(rot); + ps2_vu0_rot_matrix_y(rot, rot, degree2radian((float)flg*car->rotation_angle)); + ps2_vu0_copy_vector(v, car->direction); + ps2_vu0_apply_matrix(car->direction, rot, v); +} + +/*---------------------------- + carを加速・減速する + (flg == 1) ? 加速 : 減速 + ---------------------------*/ +void +car_accelerate(CarPtr car, int flg) +{ + car->speed += (flg == 1) ? car->speed_accel : -car->brake; + car->speed = (car->speed < 0) ? 0 : car->speed; + car->speed = (car->speed > car->speed_max) ? car->speed_max : car->speed; +} + + +/*--------------------------------- + 進行後のcarに対してコース面の内外判定を行い、 + : 現在のコース + : 現在のコースの次のコース + : 現在のコースの前のコース + に存在すればTRUEを返す + どのコースにも居ない(壁に衝突した)場合は + FALSEを返す。 + ---------------------------------*/ +static bool +car_field_check(Game *game ,CarPtr car) +{ + FieldPtr p; + FieldPtr f = field_get_actual(); + + // 現在のコースで衝突・内外判定 + p = f; + if (col_detect(&p->colface, car->vertical, car->location) == true) { + goto FIELD_CHECK_OK; + } + + // 現在のコースの次に隣接するコースで衝突・内外判定 + p = f->next; + if (col_detect(&p->colface, car->vertical, car->location) == true) { + if (field_rap_increment(1)) { + game->rap++; + } + goto FIELD_CHECK_OK; + } + + // 現在のコースの前に隣接するコースで衝突・内外判定 + p = f->prev; + if (col_detect(&p->colface, car->vertical, car->location) == true) { + field_rap_increment(-1); + goto FIELD_CHECK_OK; + } + + // どのコース上にも居ない(壁に衝突) + return false; + + FIELD_CHECK_OK: + field_set_actual(p); + return true; +} + + +/*------------------------------ + 速度speedと向きdirectionから + 進行後の位置locationを求める。 + また、進行後の衝突判定も行う。 + ------------------------------*/ +static void +car_move(Game *game,CarPtr car) +{ + FVECTOR mov, prev_location; + + ps2_vu0_scale_vector(mov, car->direction, car->speed); + ps2_vu0_copy_vector(prev_location, car->location); + ps2_vu0_add_vector(car->location, car->location, mov); + + if (car_field_check(game,car) == false) { + ps2_vu0_copy_vector(car->location, prev_location); + car->speed = car->speed*0.5; + } +} + + +static void +car_axis_rotation(CarPtr car) +{ + FMATRIX pose, yrot, yrotinv; + + ps2_vu0_unit_matrix(yrot); + ps2_vu0_rot_matrix_y(yrot, yrot, -degree2radian(car->y_angle)); + ps2_vu0_unit_matrix(yrotinv); + ps2_vu0_rot_matrix_y(yrotinv, yrotinv, degree2radian(car->y_angle)); + + { + FVECTOR yd = {0, -1, 0, 1}; + FVECTOR rotaxis; + FVECTOR q; + + ps2_vu0_outer_product(rotaxis, car->vertical, yd); + { + float scale=1/NORM(rotaxis); + rotaxis[0] *= scale; + rotaxis[1] *= scale; + rotaxis[2] *= scale; + } + + quotanion(q, rotaxis, acos(ps2_vu0_inner_product(yd, car->vertical)/(NORM(yd)*NORM(car->vertical)))); + quotanion_rotmatrix(pose, q); + } + + ps2_vu0_mul_matrix(pose, yrot, pose); + ps2_vu0_mul_matrix(pose, pose, yrotinv); + ps2_vu0_copy_matrix(car->body->transfer, pose); + ps2_vu0_rot_matrix_y(car->body->transfer, car->body->transfer, degree2radian(car->y_angle)); +} + +void car_update( Game *game, CarPtr car ) +{ + // 移動 + car_move(game,car); + + // 摩擦による速度減少 + car->speed -= 0.005; + car->speed = (car->speed < 0) ? 0 : car->speed; + + // 傾き + car_axis_rotation(car); +} + + +void +car_destroy(CarPtr p) +{ + TEXTURE *t; + + if ((t = p->body->surfaces->texture)) { + ps2util_tex_Exclude(t); + free_texture(t); + } + ps2util_obj_Free(p->body); + free(p->free_addr); + +#ifdef DEBUG + fprintf(main_fp, "free car addr = %x\n", (int)p->free_addr); +#endif +} + +// 適当に自作 +void car_id_update(Game *game, CarPtr jiki) +{ + printf("car_id_update\n"); +}
--- a/carNode.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,50 +0,0 @@ -#include <stdio.h> -#include <stdlib.h> -#include "libps2.h" -#include "ps2util.h" -#include "car.h" -#include "game.h" -#include "carNode.h" - -/* --- car.c --- */ -void car_destroy(CarPtr car); - -static CarPtr car_list; - -void -carNode_append(CarPtr new) -{ - CarPtr p = car_list; - - if (!p) { - car_list = new; - } else { - while (p->next) p = p->next; - p->next = new; - } -} - - -void -carNode_draw() -{ - CarPtr p = car_list; - - while (p) { - ps2util_obj_Draw(p->body); - p = p->next; - } -} - - -void -carNode_destroy() -{ - CarPtr p = car_list; - - while (p) { - car_destroy(p); - p = p->next; - } - car_list = NULL; -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/carNode.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,50 @@ +#include <stdio.h> +#include <stdlib.h> +#include "libps2.h" +#include "ps2util.h" +#include "car.h" +#include "game.h" +#include "carNode.h" + +/* --- car.c --- */ +void car_destroy(CarPtr car); + +static CarPtr car_list; + +void +carNode_append(CarPtr new) +{ + CarPtr p = car_list; + + if (!p) { + car_list = new; + } else { + while (p->next) p = p->next; + p->next = new; + } +} + + +void +carNode_draw() +{ + CarPtr p = car_list; + + while (p) { + ps2util_obj_Draw(p->body); + p = p->next; + } +} + + +void +carNode_destroy() +{ + CarPtr p = car_list; + + while (p) { + car_destroy(p); + p = p->next; + } + car_list = NULL; +}
--- a/col.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,136 +0,0 @@ -#include <stdio.h> -#include"libps2.h" -#include"ps2util.h" -#include"col.h" -#include"mytype.h" -#include <stdbool.h> -#include <string.h> - -extern FILE *main_fp; - -/** - * v0, v1が描く三角形と点pの内外判定(approx detection) - * 点pはv0, v1が描く面のどこかに位置している。 - * pが面の三角形の外側にあるときTRUEを戻し、 - * そうでなければFALSEを戻す。境界は含む。 - */ - - -bool -col_detect_approx(FVECTOR p, FVECTOR v0, FVECTOR v1){ - - float v_r1, v_r2, r1_r2, r1_r1, r2_r2; - float a, b, r; - - v_r1 = ps2_vu0_inner_product( p, v0 ); - v_r2 = ps2_vu0_inner_product( p, v1 ); - r1_r2 = ps2_vu0_inner_product( v0, v1 ); - r1_r1 = ps2_vu0_inner_product( v0, v0 ); - r2_r2 = ps2_vu0_inner_product( v1, v1 ); - - a = (v_r1 * r2_r2 - v_r2 * r1_r2); - b = (v_r2 * r1_r1 - v_r1 * r1_r2); - r = (r1_r1 * r2_r2 - r1_r2 * r1_r2); - - return (a>=0 && b>=0 && a+b-r<=0) ? true : false; -} - - - -/** - * 垂心oの算出. 点pからv0, v1が描く面へ垂線を引いたときの交点oを - * 垂心(orthocenter)と呼ぶ。 - */ -//なんか一回も使われていないらしいので消す、はずだった -static void -col_orthocenter(FVECTOR o, FVECTOR p, FVECTOR p0, FVECTOR normal) -{ - - FVECTOR o0, d; - - ps2_vu0_sub_vector(o0, p, p0); - o0[W_AXIS] = 0; - ps2_vu0_scale_vector( - d, normal, ps2_vu0_inner_product(o0, normal)); - - o[X_AXIS] = p[X_AXIS] - d[X_AXIS]; - o[Y_AXIS] = p[Y_AXIS] - d[Y_AXIS]; - o[Z_AXIS] = p[Z_AXIS] - d[Z_AXIS]; - o[W_AXIS] = 1; -} - -/** - * 点pと面との衝突(点pとdetection face面との垂心oがdetection face領域の - * 中にあるかを)判定衝突時(oがdetection face領域の外)はFALSEを戻し、そう - * でなければTRUE、 垂心(orthocenter)、垂心のある面の法線(normal - * vector)を戻す. - */ - - -bool -col_detect(ColFaceHd* hd, FVECTOR pose, FVECTOR p) -{ - FVECTOR o, o0; - int i; - ColFacePtr col_face=hd->colface; - for (i=0; i<hd->facenum; i++) { - - // * 垂心oを求める - col_orthocenter(o, p, col_face[i].p0, col_face[i].normal); - - // * detection face上のある点p0から垂心oへのベクトルo0を求める - ps2_vu0_sub_vector(o0, o, col_face[i].p0); - - // * ベクトルv0, v1の描く三角形とo0とで内外判定(range approx detection)を行う - if (col_detect_approx(o0, col_face[i].v0, col_face[i].v1)==true) { - goto NOCOLLISION; - } - } - return false; - NOCOLLISION: - ps2_vu0_copy_vector(p, o); - ps2_vu0_copy_vector(pose, col_face[i].normal); - return true; - - return false; -} - - -/* - * detection face作成 - */ - - -void -col_init(ColFaceHd* hd, PolygonInfo* face) -{ - - int i; - FVECTOR p1, p2; - ColFacePtr colface; - - malloc_align16(&hd->free_addr, &colface, sizeof(ColFace)*face->siz/3); - - hd->facenum = face->siz/3; - - for (i=0; i<hd->facenum; i++) { - memcpy(colface[i].p0, ((FVECTOR*)face->pnts)[i*3], sizeof(FVECTOR)); - memcpy(p1, ((FVECTOR*)face->pnts)[i*3+2], sizeof(FVECTOR)); - memcpy(p2, ((FVECTOR*)face->pnts)[i*3+1], sizeof(FVECTOR)); - - ps2_vu0_sub_vector(colface[i].v0, p1, colface[i].p0); - ps2_vu0_sub_vector(colface[i].v1, p2, colface[i].p0); - - ps2_vu0_outer_product(colface[i].normal, colface[i].v0, colface[i].v1); - ps2_vu0_normalize(colface[i].normal, colface[i].normal); - - if (colface[i].normal[1] > 0) { - colface[i].normal[0] = -colface[i].normal[0]; - colface[i].normal[1] = -colface[i].normal[1]; - colface[i].normal[2] = -colface[i].normal[2]; - } - } - - hd->colface = colface; - -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/col.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,136 @@ +#include <stdio.h> +#include"libps2.h" +#include"ps2util.h" +#include"col.h" +#include"mytype.h" +#include <stdbool.h> +#include <string.h> + +extern FILE *main_fp; + +/** + * v0, v1が描く三角形と点pの内外判定(approx detection) + * 点pはv0, v1が描く面のどこかに位置している。 + * pが面の三角形の外側にあるときTRUEを戻し、 + * そうでなければFALSEを戻す。境界は含む。 + */ + + +bool +col_detect_approx(FVECTOR p, FVECTOR v0, FVECTOR v1){ + + float v_r1, v_r2, r1_r2, r1_r1, r2_r2; + float a, b, r; + + v_r1 = ps2_vu0_inner_product( p, v0 ); + v_r2 = ps2_vu0_inner_product( p, v1 ); + r1_r2 = ps2_vu0_inner_product( v0, v1 ); + r1_r1 = ps2_vu0_inner_product( v0, v0 ); + r2_r2 = ps2_vu0_inner_product( v1, v1 ); + + a = (v_r1 * r2_r2 - v_r2 * r1_r2); + b = (v_r2 * r1_r1 - v_r1 * r1_r2); + r = (r1_r1 * r2_r2 - r1_r2 * r1_r2); + + return (a>=0 && b>=0 && a+b-r<=0) ? true : false; +} + + + +/** + * 垂心oの算出. 点pからv0, v1が描く面へ垂線を引いたときの交点oを + * 垂心(orthocenter)と呼ぶ。 + */ +//なんか一回も使われていないらしいので消す、はずだった +static void +col_orthocenter(FVECTOR o, FVECTOR p, FVECTOR p0, FVECTOR normal) +{ + + FVECTOR o0, d; + + ps2_vu0_sub_vector(o0, p, p0); + o0[W_AXIS] = 0; + ps2_vu0_scale_vector( + d, normal, ps2_vu0_inner_product(o0, normal)); + + o[X_AXIS] = p[X_AXIS] - d[X_AXIS]; + o[Y_AXIS] = p[Y_AXIS] - d[Y_AXIS]; + o[Z_AXIS] = p[Z_AXIS] - d[Z_AXIS]; + o[W_AXIS] = 1; +} + +/** + * 点pと面との衝突(点pとdetection face面との垂心oがdetection face領域の + * 中にあるかを)判定衝突時(oがdetection face領域の外)はFALSEを戻し、そう + * でなければTRUE、 垂心(orthocenter)、垂心のある面の法線(normal + * vector)を戻す. + */ + + +bool +col_detect(ColFaceHd* hd, FVECTOR pose, FVECTOR p) +{ + FVECTOR o, o0; + int i; + ColFacePtr col_face=hd->colface; + for (i=0; i<hd->facenum; i++) { + + // * 垂心oを求める + col_orthocenter(o, p, col_face[i].p0, col_face[i].normal); + + // * detection face上のある点p0から垂心oへのベクトルo0を求める + ps2_vu0_sub_vector(o0, o, col_face[i].p0); + + // * ベクトルv0, v1の描く三角形とo0とで内外判定(range approx detection)を行う + if (col_detect_approx(o0, col_face[i].v0, col_face[i].v1)==true) { + goto NOCOLLISION; + } + } + return false; + NOCOLLISION: + ps2_vu0_copy_vector(p, o); + ps2_vu0_copy_vector(pose, col_face[i].normal); + return true; + + return false; +} + + +/* + * detection face作成 + */ + + +void +col_init(ColFaceHd* hd, PolygonInfo* face) +{ + + int i; + FVECTOR p1, p2; + ColFacePtr colface; + + malloc_align16(&hd->free_addr, &colface, sizeof(ColFace)*face->siz/3); + + hd->facenum = face->siz/3; + + for (i=0; i<hd->facenum; i++) { + memcpy(colface[i].p0, ((FVECTOR*)face->pnts)[i*3], sizeof(FVECTOR)); + memcpy(p1, ((FVECTOR*)face->pnts)[i*3+2], sizeof(FVECTOR)); + memcpy(p2, ((FVECTOR*)face->pnts)[i*3+1], sizeof(FVECTOR)); + + ps2_vu0_sub_vector(colface[i].v0, p1, colface[i].p0); + ps2_vu0_sub_vector(colface[i].v1, p2, colface[i].p0); + + ps2_vu0_outer_product(colface[i].normal, colface[i].v0, colface[i].v1); + ps2_vu0_normalize(colface[i].normal, colface[i].normal); + + if (colface[i].normal[1] > 0) { + colface[i].normal[0] = -colface[i].normal[0]; + colface[i].normal[1] = -colface[i].normal[1]; + colface[i].normal[2] = -colface[i].normal[2]; + } + } + + hd->colface = colface; + +}
--- a/controler.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,109 +0,0 @@ -/* controler.c */ - -#include "libps2.h" -#include "ps2util.h" -#include "controler.h" -#include <stdbool.h> - -#include "sjoy.h" // ps2関連ファイルから - - -// 使っていないっぽい? どこで宣言してるかわからない -/* -#ifdef DEMO_CREATE -qextern void setPadValue(int pad); -#endif -extern int getPadValue(); -*/ - - - -SGO_PAD pad; - -bool padCheck() { - - int pad1; - - pad1 = sjoy_get_ps2_button( JOYPAD_1 ); - - if (pad1 & SJOY_PS2_START) { - pad.st += (pad.st < 2) ? 1 : 0; - } else { - pad.st = 0; - } - - if (pad1 & SJOY_PS2_SELECT) { - pad.se += (pad.se < 2) ? 1 : 0; - } else { - pad.se = 0; - } - if (pad1 & SJOY_PS2_LEFT) { - pad.left += (pad.left < 2) ? 1 : 0; - } else { - pad.left = 0; - } - if (pad1 & SJOY_PS2_RIGHT) { - pad.right += (pad.right < 2) ? 1 : 0; - } else { - pad.right = 0; - } - if (pad1 & SJOY_PS2_UP) { - pad.up += (pad.up < 2) ? 1 : 0; - } else { - pad.up = 0; - } - if (pad1 & SJOY_PS2_DOWN) { - pad.down += (pad.down < 2) ? 1 : 0; - } else { - pad.down = 0; - } - if (pad1 & SJOY_PS2_R1) { - pad.r1 += (pad.r1 < 2) ? 1 : 0; - } else { - pad.r1 = 0; - } - if (pad1 & SJOY_PS2_R2) { - pad.r2 += (pad.r2 < 2) ? 1 : 0; - } else { - pad.r2 = 0; - } - if (pad1 & SJOY_PS2_L1) { - pad.l1 += (pad.l1 < 2) ? 1 : 0; - } else { - pad.l1 = 0; - } - if (pad1 & SJOY_PS2_L2) { - pad.l2 += (pad.l2 < 2) ? 1 : 0; - } else { - pad.l2 = 0; - } - if (pad1 & SJOY_PS2_CROSS) { - pad.cross += (pad.cross < 2) ? 1 : 0; - } else { - pad.cross = 0; - } - if (pad1 & SJOY_PS2_CIRCLE) { - pad.circle += (pad.circle < 2) ? 1 : 0; - } else { - pad.circle = 0; - } - if (pad1 & SJOY_PS2_TRIANGLE) { - pad.triangle += (pad.triangle < 2) ? 1 : 0; - } else { - pad.triangle = 0; - } - if (pad1 & SJOY_PS2_SQUARE) { - pad.square += (pad.square < 2) ? 1 : 0; - } else { - pad.square = 0; - } - - if ( (pad1 & SJOY_PS2_SELECT) && (pad1 & SJOY_PS2_START) && - (pad1 & SJOY_PS2_L1) && (pad1 & SJOY_PS2_R1) && - (pad1 & SJOY_PS2_L2) && (pad1 & SJOY_PS2_R2)) { - return false; - } - - - return true; -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/controler.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,109 @@ +/* controler.c */ + +#include "libps2.h" +#include "ps2util.h" +#include "controler.h" +#include <stdbool.h> + +#include "sjoy.h" // ps2関連ファイルから + + +// 使っていないっぽい? どこで宣言してるかわからない +/* +#ifdef DEMO_CREATE +qextern void setPadValue(int pad); +#endif +extern int getPadValue(); +*/ + + + +SGO_PAD pad; + +bool padCheck() { + + int pad1; + + pad1 = sjoy_get_ps2_button( JOYPAD_1 ); + + if (pad1 & SJOY_PS2_START) { + pad.st += (pad.st < 2) ? 1 : 0; + } else { + pad.st = 0; + } + + if (pad1 & SJOY_PS2_SELECT) { + pad.se += (pad.se < 2) ? 1 : 0; + } else { + pad.se = 0; + } + if (pad1 & SJOY_PS2_LEFT) { + pad.left += (pad.left < 2) ? 1 : 0; + } else { + pad.left = 0; + } + if (pad1 & SJOY_PS2_RIGHT) { + pad.right += (pad.right < 2) ? 1 : 0; + } else { + pad.right = 0; + } + if (pad1 & SJOY_PS2_UP) { + pad.up += (pad.up < 2) ? 1 : 0; + } else { + pad.up = 0; + } + if (pad1 & SJOY_PS2_DOWN) { + pad.down += (pad.down < 2) ? 1 : 0; + } else { + pad.down = 0; + } + if (pad1 & SJOY_PS2_R1) { + pad.r1 += (pad.r1 < 2) ? 1 : 0; + } else { + pad.r1 = 0; + } + if (pad1 & SJOY_PS2_R2) { + pad.r2 += (pad.r2 < 2) ? 1 : 0; + } else { + pad.r2 = 0; + } + if (pad1 & SJOY_PS2_L1) { + pad.l1 += (pad.l1 < 2) ? 1 : 0; + } else { + pad.l1 = 0; + } + if (pad1 & SJOY_PS2_L2) { + pad.l2 += (pad.l2 < 2) ? 1 : 0; + } else { + pad.l2 = 0; + } + if (pad1 & SJOY_PS2_CROSS) { + pad.cross += (pad.cross < 2) ? 1 : 0; + } else { + pad.cross = 0; + } + if (pad1 & SJOY_PS2_CIRCLE) { + pad.circle += (pad.circle < 2) ? 1 : 0; + } else { + pad.circle = 0; + } + if (pad1 & SJOY_PS2_TRIANGLE) { + pad.triangle += (pad.triangle < 2) ? 1 : 0; + } else { + pad.triangle = 0; + } + if (pad1 & SJOY_PS2_SQUARE) { + pad.square += (pad.square < 2) ? 1 : 0; + } else { + pad.square = 0; + } + + if ( (pad1 & SJOY_PS2_SELECT) && (pad1 & SJOY_PS2_START) && + (pad1 & SJOY_PS2_L1) && (pad1 & SJOY_PS2_R1) && + (pad1 & SJOY_PS2_L2) && (pad1 & SJOY_PS2_R2)) { + return false; + } + + + return true; +}
--- a/field.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,264 +0,0 @@ -#include <stdio.h> -#include <stdlib.h> -#include <stdbool.h> -#include <string.h> -#include "libps2.h" -#include "ps2util.h" -#include "mytype.h" -#include "field.h" -#include "car.h" -#include "quotanion.h" -#include <stdbool.h> - -#define BUFSIZE 256 - -/* --- main.c --- */ -extern FILE *main_fp; - -static int field_num_max = 0; -static int field_num = 1; - -static FieldPtr field_list; -static FieldPtr field_actual; - -// 適当に自作:miya -PolygonInfo xml_read_file(char *colImg) -{ - PolygonInfo test; - printf("xml_read_file"); - - return test; -} - - -static FieldPtr -field_create(char *fieldImg, char *colImg, TEXTURE *tex) -{ - FieldPtr self; - OBJECT *obj; - PolygonInfo *xml; - void *free_addr; - - FVECTOR location = {0, 0, 0, 1}; - FVECTOR direction = {0, 0, 0, 1}; - - obj = ps2util_obj_Create_fromXML(fieldImg); - memcpy(obj->xyz, location, sizeof(FVECTOR)); - memcpy(obj->angle, direction, sizeof(FVECTOR)); - ps2util_obj_Renew_transMatrix(obj); - ps2util_obj_Set_effect(obj, DEFAULT_SET); - ps2util_obj_Set_texture(obj, tex); - - // xml = xml_read_file(colImg); //ここでコースの走れる場所(当たり判定) - - if (malloc_align16(&free_addr, &self, sizeof(Field)) == -1) { - fprintf(stderr, "field.c: malloc_align16 error\n"); - fflush(stderr); - exit(EXIT_FAILURE); - } - self->object = obj; - self->next = NULL; - self->prev = NULL; - self->free_addr = free_addr; -#ifdef DEBUG - fprintf(main_fp, "malloc fieldNode addr = %x(free), %x(obj)\n", (int)free_addr, (int)self); -#endif - col_init(&self->colface, xml); - -#ifdef DEBUG - fprintf(main_fp, " facenum = %d\n", self->colface.facenum); - fprintf(main_fp, " facenum = %x(free), ", (int)self->colface.free_addr); - fprintf(main_fp, "facenum = %x(obj)\n", (int)self->colface.colface); -#endif - - //xml_free(xml); - - return self; -} - - - -static void -field_new_readCSV(FILE *fp, int id) -{ - FieldPtr fieldHead = NULL; - FieldPtr newField = NULL; - FieldPtr prevField = NULL; - char buff[BUFSIZE], *bufp; - char fieldImg[BUFSIZE], colImg[BUFSIZE], texname[BUFSIZE]; - TEXTURE *tex = NULL; - int course_id; - bool flag = false; - - while ((bufp = fgets(buff, BUFSIZE, fp)) != NULL) { - bufp++; - - switch (buff[0]) { - case 'n': // コースIDの読み取り - if (!flag) { - sscanf(bufp, " %d\n", &course_id); - if (id == course_id) { - flag = true; - } - } else { - goto FINISH_LOAD; - } - break; - case 't': // テクスチャのロード - if (flag) { - sscanf(bufp, " %s\n", texname); - //tex = read_png_file(texname); - ps2util_tex_Set(tex); - } - break; - case 'c': // コースのロード - if (flag) { - sscanf(bufp, " %s %s\n", fieldImg, colImg); - newField = field_create(fieldImg, colImg, tex); - if (!fieldHead) { - fieldHead = prevField = newField; - } else { - prevField->next = newField; - newField->prev = prevField; - prevField = newField; - } - newField->init = fieldHead; - field_num_max++; - } - break; - default: - break; - } - } - - FINISH_LOAD: - // 先頭と最後尾のリンクを張る - newField->next = newField->init; - newField->init->prev = newField; - - field_list = field_actual = fieldHead; -} - - -/*---------------------/ - FieldPtr - field_init: - 指定したファイルからコースを生成する。 - 戻り値 - コース先頭のポインタ -/---------------------*/ -void -field_init(int id) -{ - FILE *fp; - char *filename = "course/course.dat"; - - if (!(fp = fopen(filename, "r"))) { - fprintf(main_fp, "error read file %s\n", filename); - exit(EXIT_FAILURE); - } - field_new_readCSV(fp, id); - fclose(fp); -} - - -static void -field_draw(FieldPtr p) -{ - ps2_vu0_unit_matrix(p->object->transfer); - - p->object->transfer[3][0] = p->location[0]; - p->object->transfer[3][1] = p->location[1]; - p->object->transfer[3][2] = p->location[2]; - p->object->transfer[3][3] = p->location[3]; - ps2util_obj_Draw(p->object); -} - - -void field_update(CarPtr car) -{ - FieldPtr p; - - p = field_actual; - // current - p->location[0] = -car->location[0]; - p->location[1] = -car->location[1]; - p->location[2] = -car->location[2]; - p->location[3] = 1; - field_draw(p); - - // next - p = field_actual->next; - if (p) { - p->location[0] = -car->location[0]; - p->location[1] = -car->location[1]; - p->location[2] = -car->location[2]; - p->location[3] = 1; - field_draw(p); - } - - // prev - p = field_actual->prev; - if (p) { - p->location[0] = -car->location[0]; - p->location[1] = -car->location[1]; - p->location[2] = -car->location[2]; - p->location[3] = 1; - field_draw(p); - } -} - -void -field_destroy() -{ - FieldPtr p = field_list; - FieldPtr d; - TEXTURE *t; - - p->prev->next = NULL; - - t = p->object->surfaces->texture; - ps2util_tex_Exclude(t); - free_texture(t); - - while (p) { - d = p; - p = p->next; - ps2util_obj_Free(d->object); - free(d->colface.free_addr); - free(d->free_addr); -#ifdef DEBUG - fprintf(main_fp, "free fieldNode addr = %x\n", (int)d->free_addr); -#endif - } - - field_num_max = 0; - field_num = 1; -} - -/* - * 周回記録。1周する毎に1を返す。 - */ -int -field_rap_increment(int n) -{ - field_num += n; - if (field_num > field_num_max) { - field_num = 1; - return 1; - } else { - return 0; - } -} - -void -field_set_actual(FieldPtr p) -{ - field_actual = p; -} - -FieldPtr -field_get_actual() -{ - return field_actual; -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/field.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,264 @@ +#include <stdio.h> +#include <stdlib.h> +#include <stdbool.h> +#include <string.h> +#include "libps2.h" +#include "ps2util.h" +#include "mytype.h" +#include "field.h" +#include "car.h" +#include "quotanion.h" +#include <stdbool.h> + +#define BUFSIZE 256 + +/* --- main.c --- */ +extern FILE *main_fp; + +static int field_num_max = 0; +static int field_num = 1; + +static FieldPtr field_list; +static FieldPtr field_actual; + +// 適当に自作:miya +PolygonInfo xml_read_file(char *colImg) +{ + PolygonInfo test; + printf("xml_read_file"); + + return test; +} + + +static FieldPtr +field_create(char *fieldImg, char *colImg, TEXTURE *tex) +{ + FieldPtr self; + OBJECT *obj; + PolygonInfo *xml; + void *free_addr; + + FVECTOR location = {0, 0, 0, 1}; + FVECTOR direction = {0, 0, 0, 1}; + + obj = ps2util_obj_Create_fromXML(fieldImg); + memcpy(obj->xyz, location, sizeof(FVECTOR)); + memcpy(obj->angle, direction, sizeof(FVECTOR)); + ps2util_obj_Renew_transMatrix(obj); + ps2util_obj_Set_effect(obj, DEFAULT_SET); + ps2util_obj_Set_texture(obj, tex); + + // xml = xml_read_file(colImg); //ここでコースの走れる場所(当たり判定) + + if (malloc_align16(&free_addr, &self, sizeof(Field)) == -1) { + fprintf(stderr, "field.c: malloc_align16 error\n"); + fflush(stderr); + exit(EXIT_FAILURE); + } + self->object = obj; + self->next = NULL; + self->prev = NULL; + self->free_addr = free_addr; +#ifdef DEBUG + fprintf(main_fp, "malloc fieldNode addr = %x(free), %x(obj)\n", (int)free_addr, (int)self); +#endif + col_init(&self->colface, xml); + +#ifdef DEBUG + fprintf(main_fp, " facenum = %d\n", self->colface.facenum); + fprintf(main_fp, " facenum = %x(free), ", (int)self->colface.free_addr); + fprintf(main_fp, "facenum = %x(obj)\n", (int)self->colface.colface); +#endif + + //xml_free(xml); + + return self; +} + + + +static void +field_new_readCSV(FILE *fp, int id) +{ + FieldPtr fieldHead = NULL; + FieldPtr newField = NULL; + FieldPtr prevField = NULL; + char buff[BUFSIZE], *bufp; + char fieldImg[BUFSIZE], colImg[BUFSIZE], texname[BUFSIZE]; + TEXTURE *tex = NULL; + int course_id; + bool flag = false; + + while ((bufp = fgets(buff, BUFSIZE, fp)) != NULL) { + bufp++; + + switch (buff[0]) { + case 'n': // コースIDの読み取り + if (!flag) { + sscanf(bufp, " %d\n", &course_id); + if (id == course_id) { + flag = true; + } + } else { + goto FINISH_LOAD; + } + break; + case 't': // テクスチャのロード + if (flag) { + sscanf(bufp, " %s\n", texname); + //tex = read_png_file(texname); + ps2util_tex_Set(tex); + } + break; + case 'c': // コースのロード + if (flag) { + sscanf(bufp, " %s %s\n", fieldImg, colImg); + newField = field_create(fieldImg, colImg, tex); + if (!fieldHead) { + fieldHead = prevField = newField; + } else { + prevField->next = newField; + newField->prev = prevField; + prevField = newField; + } + newField->init = fieldHead; + field_num_max++; + } + break; + default: + break; + } + } + + FINISH_LOAD: + // 先頭と最後尾のリンクを張る + newField->next = newField->init; + newField->init->prev = newField; + + field_list = field_actual = fieldHead; +} + + +/*---------------------/ + FieldPtr + field_init: + 指定したファイルからコースを生成する。 + 戻り値 + コース先頭のポインタ +/---------------------*/ +void +field_init(int id) +{ + FILE *fp; + char *filename = "course/course.dat"; + + if (!(fp = fopen(filename, "r"))) { + fprintf(main_fp, "error read file %s\n", filename); + exit(EXIT_FAILURE); + } + field_new_readCSV(fp, id); + fclose(fp); +} + + +static void +field_draw(FieldPtr p) +{ + ps2_vu0_unit_matrix(p->object->transfer); + + p->object->transfer[3][0] = p->location[0]; + p->object->transfer[3][1] = p->location[1]; + p->object->transfer[3][2] = p->location[2]; + p->object->transfer[3][3] = p->location[3]; + ps2util_obj_Draw(p->object); +} + + +void field_update(CarPtr car) +{ + FieldPtr p; + + p = field_actual; + // current + p->location[0] = -car->location[0]; + p->location[1] = -car->location[1]; + p->location[2] = -car->location[2]; + p->location[3] = 1; + field_draw(p); + + // next + p = field_actual->next; + if (p) { + p->location[0] = -car->location[0]; + p->location[1] = -car->location[1]; + p->location[2] = -car->location[2]; + p->location[3] = 1; + field_draw(p); + } + + // prev + p = field_actual->prev; + if (p) { + p->location[0] = -car->location[0]; + p->location[1] = -car->location[1]; + p->location[2] = -car->location[2]; + p->location[3] = 1; + field_draw(p); + } +} + +void +field_destroy() +{ + FieldPtr p = field_list; + FieldPtr d; + TEXTURE *t; + + p->prev->next = NULL; + + t = p->object->surfaces->texture; + ps2util_tex_Exclude(t); + free_texture(t); + + while (p) { + d = p; + p = p->next; + ps2util_obj_Free(d->object); + free(d->colface.free_addr); + free(d->free_addr); +#ifdef DEBUG + fprintf(main_fp, "free fieldNode addr = %x\n", (int)d->free_addr); +#endif + } + + field_num_max = 0; + field_num = 1; +} + +/* + * 周回記録。1周する毎に1を返す。 + */ +int +field_rap_increment(int n) +{ + field_num += n; + if (field_num > field_num_max) { + field_num = 1; + return 1; + } else { + return 0; + } +} + +void +field_set_actual(FieldPtr p) +{ + field_actual = p; +} + +FieldPtr +field_get_actual() +{ + return field_actual; +}
--- a/gFont.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,169 +0,0 @@ -/* - * $Id$ - * - * フォント表示。といっても結局スプライトです。 - * gSprite.c と一緒にしてもよかったんだけど - * 文字は文字でいろいろあるので分けてみる - */ -#include <stdio.h> -#include <stdlib.h> -#include <stdbool.h> -#include "libps2.h" -#include "ps2util.h" -#include "gSprite.h" - -#define DEFOBJ 120 -#define SPRITE_COL 0x4f -#define SCREEN_HALF_W 320 -#define SCREEN_HALF_H 240 -#define CHAR_W_SIZE 17 -#define CHAR_H_SIZE 34 - -static SpriteTable sptable[DEFOBJ]; -static ps2utilSprite sp[DEFOBJ*2]; // 表示スプライト用スタック -static unsigned int sp_counter; -static bool flag_spriteInited = false; // スプライトロードフラグ - -static TEXTURE *font_tex; - -static void -gFont_Init_Png(char *texname) -{ - if (!(font_tex = read_png_file(texname))) { - fprintf(stderr, - "cannot creat texture - gFont_Init_Png().\n"); - fflush(stderr); - exit(EXIT_FAILURE); - } - - if (ps2util_tex_Set(font_tex) == -1) { - fprintf(stderr, - "cannot set texture - gFont_Init_Png().\n"); - fflush(stderr); - exit(EXIT_FAILURE); - } -} - -static void -gFont_Create() -{ - int i; - for (i=0; i<DEFOBJ; i++) { - if (ps2util_sprite_Create(&sp[i], font_tex) == -1) { - fprintf(stderr, - "cannot create sprite - gFont_Create()\n"); - fflush(stderr); - exit(EXIT_FAILURE); - } - ps2util_sprite_Unuse_alpha(&sp[i]); - } - - - flag_spriteInited = true; -} - -static void -gFont_DefSprite(int number, int x, int y, int w, int h) -{ - sptable[number].tx = x; - sptable[number].ty = y; - sptable[number].tw = w; - sptable[number].th = h; -} - -void -gFont_Init() -{ - int i, j; - int number = 0; - - gFont_Init_Png("img/font.png"); - gFont_Create(); // スプライト生成 - - for (i=0; i<7; i++) { - for (j=0; j<15; j++) { - gFont_DefSprite(number, j*17, i*34, 17, 34); - number++; - } - } -} - - -static void -gFont_PutSprite(int number, int x, int y) -{ - ps2utilSprite *p = &sp[sp_counter]; - - // ushortってなんですか?:miya - /* - ps2util_sprite_Set_basicAttribute( - p, - (ushort)x, (ushort)y, - (ushort)sptable[number].tw*1.5, (ushort)sptable[number].th*1.5, - (ushort)sptable[number].tx, (ushort)sptable[number].ty, - (ushort)sptable[number].tw, (ushort)sptable[number].th, - SPRITE_PRIO_FOREGROUND); - */ - - ps2util_sprite_Request(p); - sp_counter++; -} - - -static void -gFont_Clear() -{ - int i; - - for (i=0; i<DEFOBJ; i++) { - sprite_disappear(&sp[i].attribute); - } - sp_counter = 0; -} - -void -gFont_Draw_Reset() -{ - if (flag_spriteInited == true) { - gFont_Clear(); - } -} - -static int -get_number_char(char a) -{ - return (int)a-32; -} - -/* - * str をスプライド表示 - */ -void -gFont_SetString(char *str, int x, int y) -{ - int number; - - while (*str != '\0') { - number = get_number_char(*str); - gFont_PutSprite(number, x, y); - str++; - x += (int)CHAR_W_SIZE*1.5; - } -} - -/* - * numを文字列に変換してSetStringに渡す - */ -void -gFont_SetStringInt(int num, int x, int y) -{ - char bufp[256]; - - snprintf(bufp, 256, "%d", num); - gFont_SetString(bufp, x, y); -} - -void -gFont_SetFont_OP() -{ -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gFont.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,169 @@ +/* + * $Id$ + * + * フォント表示。といっても結局スプライトです。 + * gSprite.c と一緒にしてもよかったんだけど + * 文字は文字でいろいろあるので分けてみる + */ +#include <stdio.h> +#include <stdlib.h> +#include <stdbool.h> +#include "libps2.h" +#include "ps2util.h" +#include "gSprite.h" + +#define DEFOBJ 120 +#define SPRITE_COL 0x4f +#define SCREEN_HALF_W 320 +#define SCREEN_HALF_H 240 +#define CHAR_W_SIZE 17 +#define CHAR_H_SIZE 34 + +static SpriteTable sptable[DEFOBJ]; +static ps2utilSprite sp[DEFOBJ*2]; // 表示スプライト用スタック +static unsigned int sp_counter; +static bool flag_spriteInited = false; // スプライトロードフラグ + +static TEXTURE *font_tex; + +static void +gFont_Init_Png(char *texname) +{ + if (!(font_tex = read_png_file(texname))) { + fprintf(stderr, + "cannot creat texture - gFont_Init_Png().\n"); + fflush(stderr); + exit(EXIT_FAILURE); + } + + if (ps2util_tex_Set(font_tex) == -1) { + fprintf(stderr, + "cannot set texture - gFont_Init_Png().\n"); + fflush(stderr); + exit(EXIT_FAILURE); + } +} + +static void +gFont_Create() +{ + int i; + for (i=0; i<DEFOBJ; i++) { + if (ps2util_sprite_Create(&sp[i], font_tex) == -1) { + fprintf(stderr, + "cannot create sprite - gFont_Create()\n"); + fflush(stderr); + exit(EXIT_FAILURE); + } + ps2util_sprite_Unuse_alpha(&sp[i]); + } + + + flag_spriteInited = true; +} + +static void +gFont_DefSprite(int number, int x, int y, int w, int h) +{ + sptable[number].tx = x; + sptable[number].ty = y; + sptable[number].tw = w; + sptable[number].th = h; +} + +void +gFont_Init() +{ + int i, j; + int number = 0; + + gFont_Init_Png("img/font.png"); + gFont_Create(); // スプライト生成 + + for (i=0; i<7; i++) { + for (j=0; j<15; j++) { + gFont_DefSprite(number, j*17, i*34, 17, 34); + number++; + } + } +} + + +static void +gFont_PutSprite(int number, int x, int y) +{ + ps2utilSprite *p = &sp[sp_counter]; + + // ushortってなんですか?:miya + /* + ps2util_sprite_Set_basicAttribute( + p, + (ushort)x, (ushort)y, + (ushort)sptable[number].tw*1.5, (ushort)sptable[number].th*1.5, + (ushort)sptable[number].tx, (ushort)sptable[number].ty, + (ushort)sptable[number].tw, (ushort)sptable[number].th, + SPRITE_PRIO_FOREGROUND); + */ + + ps2util_sprite_Request(p); + sp_counter++; +} + + +static void +gFont_Clear() +{ + int i; + + for (i=0; i<DEFOBJ; i++) { + sprite_disappear(&sp[i].attribute); + } + sp_counter = 0; +} + +void +gFont_Draw_Reset() +{ + if (flag_spriteInited == true) { + gFont_Clear(); + } +} + +static int +get_number_char(char a) +{ + return (int)a-32; +} + +/* + * str をスプライド表示 + */ +void +gFont_SetString(char *str, int x, int y) +{ + int number; + + while (*str != '\0') { + number = get_number_char(*str); + gFont_PutSprite(number, x, y); + str++; + x += (int)CHAR_W_SIZE*1.5; + } +} + +/* + * numを文字列に変換してSetStringに渡す + */ +void +gFont_SetStringInt(int num, int x, int y) +{ + char bufp[256]; + + snprintf(bufp, 256, "%d", num); + gFont_SetString(bufp, x, y); +} + +void +gFont_SetFont_OP() +{ +}
--- a/gSprite.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,157 +0,0 @@ -#include <stdio.h> -#include <stdlib.h> -#include "libps2.h" -#include "ps2util.h" -#include "gSprite.h" -#include <stdbool.h> - -#define DEFOBJ 100 -#define SPRITE_COL 0x4f -#define SCREEN_HALF_W 320 -#define SCREEN_HALF_H 240 - -static SpriteTable sptable[DEFOBJ]; -static ps2utilSprite sp[DEFOBJ]; // 表示スプライト用スタック -static unsigned int sp_counter; -static bool flag_spriteInited = false; // スプライトロードフラグ - -static TEXTURE *sprite_tex; - - -void -gSprite_DefSprite(int number, int tx, int ty, int tw, int th) -{ - sptable[number].tx = tx; - sptable[number].ty = ty; - sptable[number].tw = tw; - sptable[number].th = th; -} - -void -gSprite_PutSprite(int number, int x, int y) -{ - ps2utilSprite *p = &sp[sp_counter]; - - ps2util_sprite_Set_basicAttribute( - p, - (unsigned short)x, (unsigned short)y, - (unsigned short)sptable[number].tw*2, (unsigned short)sptable[number].th*2, - (unsigned short)sptable[number].tx, (unsigned short)sptable[number].ty, - (unsigned short)sptable[number].tw, (unsigned short)sptable[number].th, - SPRITE_PRIO_FOREGROUND); - - ps2util_sprite_Request(p); - sp_counter++; -} - -void -gSprite_PutSpriteEx(int number, int x, int y, float w, float h) -{ - ps2utilSprite *p = &sp[sp_counter]; - - ps2util_sprite_Set_basicAttribute( - p, - (unsigned short)x, (unsigned short)y, - (unsigned short)sptable[number].tw*w, (unsigned short)sptable[number].th*h, - (unsigned short)sptable[number].tx, (unsigned short)sptable[number].ty, - (unsigned short)sptable[number].tw, (unsigned short)sptable[number].th, - SPRITE_PRIO_FOREGROUND); - - ps2util_sprite_Request(p); - sp_counter++; -} - - -static void -gSprite_Init_Png(char *texname) -{ - if (!(sprite_tex = read_png_file(texname))) { - fprintf(stderr, - "cannot creat texture - init_png().\n"); - fflush(stderr); - exit(EXIT_FAILURE); - } - - if (ps2util_tex_Set(sprite_tex) == -1) { - fprintf(stderr, - "cannot set texture - init_png().\n"); - fflush(stderr); - exit(EXIT_FAILURE); - } - -} - -static void -gSprite_Create() -{ - int i; - - for (i=0; i<DEFOBJ; i++) { - if (ps2util_sprite_Create(&sp[i], sprite_tex) == -1) { - fprintf(stderr, - "cannot create sprite No.%d - create_sprite()\n", i); - fflush(stderr); - exit(EXIT_FAILURE); - } - ps2util_sprite_Unuse_alpha(&sp[i]); - } - - flag_spriteInited = false; -} - - -void -gSprite_Init() -{ - ps2util_graphic_Init(); - gSprite_Init_Png("img/main2.png"); - gSprite_Create(); // スプライト生成 - - - // スプライトの登録 - gSprite_DefSprite(10, 1, 1, 512, 666); // タイトル - gSprite_DefSprite(17, 1, 35, 33, 33); // 選択マーク - gSprite_DefSprite(23, 1, 1, 106, 34); // スピードメーター - gSprite_DefSprite(24, 51, 40, 18, 20); // 右矢印 - gSprite_DefSprite(25, 33, 40, 17, 20); // 左矢印 - gSprite_DefSprite(26, 56, 89, 55, 26); // km/h - gSprite_DefSprite(27, 62, 62, 39, 26); // Rap - gSprite_DefSprite(28, 430, 62, 53, 46); // 1p - gSprite_DefSprite(29, 460, 6, 53, 46); // 2P - gSprite_DefSprite(51, 333, 116, 165, 140); // 選択画面の車 - gSprite_DefSprite(52, 181, 116, 165, 140); - gSprite_DefSprite(53, 12, 116, 165, 140); - gSprite_DefSprite(81, 115, 1, 148, 114); // 選択画面のコース - // 本当は (82, 272,...)です。二つ目のコース絵がないので - gSprite_DefSprite(82, 272, 1, 148, 114); - -} - - -static void -gSprite_Clear() -{ - int i; - - for (i=0; i<DEFOBJ; i++) { - sprite_disappear(&sp[i].attribute); - } - sp_counter = 0; -} - - - -void -gSprite_Draw_Reset() -{ - if (flag_spriteInited == true) { - gSprite_Clear(); - } -} - - - -void -gSprite_PutSprite_Pause() -{ -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gSprite.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,157 @@ +#include <stdio.h> +#include <stdlib.h> +#include "libps2.h" +#include "ps2util.h" +#include "gSprite.h" +#include <stdbool.h> + +#define DEFOBJ 100 +#define SPRITE_COL 0x4f +#define SCREEN_HALF_W 320 +#define SCREEN_HALF_H 240 + +static SpriteTable sptable[DEFOBJ]; +static ps2utilSprite sp[DEFOBJ]; // 表示スプライト用スタック +static unsigned int sp_counter; +static bool flag_spriteInited = false; // スプライトロードフラグ + +static TEXTURE *sprite_tex; + + +void +gSprite_DefSprite(int number, int tx, int ty, int tw, int th) +{ + sptable[number].tx = tx; + sptable[number].ty = ty; + sptable[number].tw = tw; + sptable[number].th = th; +} + +void +gSprite_PutSprite(int number, int x, int y) +{ + ps2utilSprite *p = &sp[sp_counter]; + + ps2util_sprite_Set_basicAttribute( + p, + (unsigned short)x, (unsigned short)y, + (unsigned short)sptable[number].tw*2, (unsigned short)sptable[number].th*2, + (unsigned short)sptable[number].tx, (unsigned short)sptable[number].ty, + (unsigned short)sptable[number].tw, (unsigned short)sptable[number].th, + SPRITE_PRIO_FOREGROUND); + + ps2util_sprite_Request(p); + sp_counter++; +} + +void +gSprite_PutSpriteEx(int number, int x, int y, float w, float h) +{ + ps2utilSprite *p = &sp[sp_counter]; + + ps2util_sprite_Set_basicAttribute( + p, + (unsigned short)x, (unsigned short)y, + (unsigned short)sptable[number].tw*w, (unsigned short)sptable[number].th*h, + (unsigned short)sptable[number].tx, (unsigned short)sptable[number].ty, + (unsigned short)sptable[number].tw, (unsigned short)sptable[number].th, + SPRITE_PRIO_FOREGROUND); + + ps2util_sprite_Request(p); + sp_counter++; +} + + +static void +gSprite_Init_Png(char *texname) +{ + if (!(sprite_tex = read_png_file(texname))) { + fprintf(stderr, + "cannot creat texture - init_png().\n"); + fflush(stderr); + exit(EXIT_FAILURE); + } + + if (ps2util_tex_Set(sprite_tex) == -1) { + fprintf(stderr, + "cannot set texture - init_png().\n"); + fflush(stderr); + exit(EXIT_FAILURE); + } + +} + +static void +gSprite_Create() +{ + int i; + + for (i=0; i<DEFOBJ; i++) { + if (ps2util_sprite_Create(&sp[i], sprite_tex) == -1) { + fprintf(stderr, + "cannot create sprite No.%d - create_sprite()\n", i); + fflush(stderr); + exit(EXIT_FAILURE); + } + ps2util_sprite_Unuse_alpha(&sp[i]); + } + + flag_spriteInited = false; +} + + +void +gSprite_Init() +{ + ps2util_graphic_Init(); + gSprite_Init_Png("img/main2.png"); + gSprite_Create(); // スプライト生成 + + + // スプライトの登録 + gSprite_DefSprite(10, 1, 1, 512, 666); // タイトル + gSprite_DefSprite(17, 1, 35, 33, 33); // 選択マーク + gSprite_DefSprite(23, 1, 1, 106, 34); // スピードメーター + gSprite_DefSprite(24, 51, 40, 18, 20); // 右矢印 + gSprite_DefSprite(25, 33, 40, 17, 20); // 左矢印 + gSprite_DefSprite(26, 56, 89, 55, 26); // km/h + gSprite_DefSprite(27, 62, 62, 39, 26); // Rap + gSprite_DefSprite(28, 430, 62, 53, 46); // 1p + gSprite_DefSprite(29, 460, 6, 53, 46); // 2P + gSprite_DefSprite(51, 333, 116, 165, 140); // 選択画面の車 + gSprite_DefSprite(52, 181, 116, 165, 140); + gSprite_DefSprite(53, 12, 116, 165, 140); + gSprite_DefSprite(81, 115, 1, 148, 114); // 選択画面のコース + // 本当は (82, 272,...)です。二つ目のコース絵がないので + gSprite_DefSprite(82, 272, 1, 148, 114); + +} + + +static void +gSprite_Clear() +{ + int i; + + for (i=0; i<DEFOBJ; i++) { + sprite_disappear(&sp[i].attribute); + } + sp_counter = 0; +} + + + +void +gSprite_Draw_Reset() +{ + if (flag_spriteInited == true) { + gSprite_Clear(); + } +} + + + +void +gSprite_PutSprite_Pause() +{ +}
--- a/game.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,45 +0,0 @@ -/* game.c */ - -#include <stdio.h> -#include <stdlib.h> -#include <stdbool.h> -#include "libps2.h" -#include "ps2util.h" -#include "controler.h" -//#include "linda/lindaapi.h" -#include "game.h" -#include "car.h" - -#include "schedule.h" - - -/* linda.c */ -#ifdef LINDA -//extern int linda_init(); -#else -#define linda_init 1 -#endif - -void game_main() -{ - Game game; - bool flg = true; -#ifdef LINDA - game->play_id = linda_init(); -#endif - - while (1) { - flg = padCheck(); - - if (flg == false) { - break; - } - schedule(&game); - -#ifdef LINDA - psx_sync_n(); -#endif - } -} - -//ceriumのmainルーチンに直す。
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/game.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,45 @@ +/* game.c */ + +#include <stdio.h> +#include <stdlib.h> +#include <stdbool.h> +#include "libps2.h" +#include "ps2util.h" +#include "controler.h" +//#include "linda/lindaapi.h" +#include "game.h" +#include "car.h" + +#include "schedule.h" + + +/* linda.c */ +#ifdef LINDA +//extern int linda_init(); +#else +#define linda_init 1 +#endif + +void game_main() +{ + Game game; + bool flg = true; +#ifdef LINDA + game->play_id = linda_init(); +#endif + + while (1) { + flg = padCheck(); + + if (flg == false) { + break; + } + schedule(&game); + +#ifdef LINDA + psx_sync_n(); +#endif + } +} + +//ceriumのmainルーチンに直す。
--- a/game_time.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,114 +0,0 @@ -/** - * 2006/07/31(MON) Nobutaka OSHIRO - */ -#include "game_time.h" - -int game_time_get_msec() { - - struct timeval now; - int time_msec; - - /** - * *** man timeval *** - * struct timeval { - * time_t tv_sec // second - * suseconds_t tv_usec; // micro sec - * }; - **/ - - // get time micro second ( micro second = 1 / 1000,000 second) - gettimeofday(&now, NULL); - - // evaluation milli second ( milli second = 1 / 1000 second ) - time_msec = now.tv_sec * 1000 + now.tv_usec / 1000; - - return time_msec; -} - - -int game_time_conv_ms2cs (int msec) -{ - return msec / 10 % 100; /** 1/100 sec **/ -} - -int game_time_conv_ms2sec (int msec) -{ - return msec / 1000 % 60; -} - -int game_time_conv_ms2minute (int msec) -{ - return msec / 60000 % 60; -} - - -/** - * NAME: - * game_time_set_raptime - Return RAP TIME ("XXX:XX:XX") - * - * DESCRIPTION: - * 1. convert (int --> string) - * (int) argument2 (milli second) --> "XXX:XX:XX" - * - * 2. set ( string --> char * ) - * "XXX:XX:XX" --> char *argument1 - **/ -void game_time_set_raptime (char *s,int msec) -{ - char chminute[3]; - char chsec[2]; - char chcsec[2]; - char raptime[10]; - int minute = game_time_conv_ms2minute (msec); - int sec = game_time_conv_ms2sec (msec); - int csec = game_time_conv_ms2cs (msec); - int i; - - - if (minute < 10 ){ - chminute[0] = ' '; - chminute[1] = '0'; - chminute[2] = minute + 48; - } else if (minute < 100 ) { - chminute[0] = ' '; - chminute[1] = (minute / 10) + 48; - chminute[2] = (minute % 10) + 48; - } else { - chminute[0] = (minute / 100) + 48; - chminute[1] = (minute / 10) + 48; - chminute[2] = (minute % 10) + 48; - } - if (sec < 10 ){ - chsec[0] = '0'; - chsec[1] = sec + 48; - } else { - chsec[0] = (sec / 10) + 48; - chsec[1] = (sec % 10) + 48; - } - - if (csec < 10 ){ - chcsec[0] = '0'; - chcsec[1] = csec + 48; - } else { - chcsec[0] = (csec / 10) + 48; - chcsec[1] = (csec % 10) + 48; - } - - - /** raptime[0-9] == "XXX:XX:XX\0" **/ - raptime[0] = chminute[0]; - raptime[1] = chminute[1]; - raptime[2] = chminute[2]; - raptime[3] = ':'; - raptime[4] = chsec[0]; - raptime[5] = chsec[1]; - raptime[6] = ':'; - raptime[7] = chcsec[0]; - raptime[8] = chcsec[1]; - raptime[9] = '\0'; // NULL - - - for (i = 0; raptime[i] != '\0'; i++) { - s[i] = raptime[i]; - } -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/game_time.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,114 @@ +/** + * 2006/07/31(MON) Nobutaka OSHIRO + */ +#include "game_time.h" + +int game_time_get_msec() { + + struct timeval now; + int time_msec; + + /** + * *** man timeval *** + * struct timeval { + * time_t tv_sec // second + * suseconds_t tv_usec; // micro sec + * }; + **/ + + // get time micro second ( micro second = 1 / 1000,000 second) + gettimeofday(&now, NULL); + + // evaluation milli second ( milli second = 1 / 1000 second ) + time_msec = now.tv_sec * 1000 + now.tv_usec / 1000; + + return time_msec; +} + + +int game_time_conv_ms2cs (int msec) +{ + return msec / 10 % 100; /** 1/100 sec **/ +} + +int game_time_conv_ms2sec (int msec) +{ + return msec / 1000 % 60; +} + +int game_time_conv_ms2minute (int msec) +{ + return msec / 60000 % 60; +} + + +/** + * NAME: + * game_time_set_raptime - Return RAP TIME ("XXX:XX:XX") + * + * DESCRIPTION: + * 1. convert (int --> string) + * (int) argument2 (milli second) --> "XXX:XX:XX" + * + * 2. set ( string --> char * ) + * "XXX:XX:XX" --> char *argument1 + **/ +void game_time_set_raptime (char *s,int msec) +{ + char chminute[3]; + char chsec[2]; + char chcsec[2]; + char raptime[10]; + int minute = game_time_conv_ms2minute (msec); + int sec = game_time_conv_ms2sec (msec); + int csec = game_time_conv_ms2cs (msec); + int i; + + + if (minute < 10 ){ + chminute[0] = ' '; + chminute[1] = '0'; + chminute[2] = minute + 48; + } else if (minute < 100 ) { + chminute[0] = ' '; + chminute[1] = (minute / 10) + 48; + chminute[2] = (minute % 10) + 48; + } else { + chminute[0] = (minute / 100) + 48; + chminute[1] = (minute / 10) + 48; + chminute[2] = (minute % 10) + 48; + } + if (sec < 10 ){ + chsec[0] = '0'; + chsec[1] = sec + 48; + } else { + chsec[0] = (sec / 10) + 48; + chsec[1] = (sec % 10) + 48; + } + + if (csec < 10 ){ + chcsec[0] = '0'; + chcsec[1] = csec + 48; + } else { + chcsec[0] = (csec / 10) + 48; + chcsec[1] = (csec % 10) + 48; + } + + + /** raptime[0-9] == "XXX:XX:XX\0" **/ + raptime[0] = chminute[0]; + raptime[1] = chminute[1]; + raptime[2] = chminute[2]; + raptime[3] = ':'; + raptime[4] = chsec[0]; + raptime[5] = chsec[1]; + raptime[6] = ':'; + raptime[7] = chcsec[0]; + raptime[8] = chcsec[1]; + raptime[9] = '\0'; // NULL + + + for (i = 0; raptime[i] != '\0'; i++) { + s[i] = raptime[i]; + } +}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hikae Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,20 @@ +hg rename camera.c camera.cc +hg rename car.c car.cc +hg rename carNode.c carNode.cc +hg rename col.c col.cc +hg rename controler.c controler.cc +hg rename field.c field.cc +hg rename gFont.c gFont.cc +hg rename gSprite.c gSprite.cc +hg rename game.c game.cc +hg rename game_time.c game_time.cc +hg rename light.c light.cc +hg rename linda.c linda.cc +hg rename main.c main.cc +hg rename mytype.c mytype.cc +hg rename ps2util.c ps2util.cc +hg rename quotanion.c quotanion.cc +hg rename schedule.c schedule.cc +hg rename sjoy.c sjoy.cc +hg rename test_vector.c test_vector.cc +hg rename title_scene.c title_scene.cc
--- a/light.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,77 +0,0 @@ -/* light.c */ - -#include <stdio.h> -#include "libps2.h" -#include "light.h" - -#include "sjoy.h" // ps2関連ファイルから - -FMATRIX normal_light; -FMATRIX light_color; - - -void init_light(LIGHT *l) -{ - //Three lights in all. - // The color of the light of "light0" is color0. - // The color of the light of "light1" is color1. - // The color of the light of "light2" is color2. - - - l->light0[0] = 0.0; - l->light0[1] = 0.0; - l->light0[2] = 1.0; - l->light0[3] = 1.0; - - l->light1[0] = 0.0; - l->light1[1] = -1.0; - l->light1[2] = 0.0; - l->light1[3] = 1.0; - - l->light2[0] = 1.0; - l->light2[1] = 1.0; - l->light2[2] = 1.0; - l->light2[3] = 1.0; - - l->color0[0] = 0.4; - l->color0[1] = 0.4; - l->color0[2] = 0.4; - l->color0[3] = 1.0; - - l->color1[0] = 0.4; - l->color1[1] = 0.4; - l->color1[2] = 0.4; - l->color1[3] = 1.0; - - l->color2[0] = 0.4; - l->color2[1] = 0.4; - l->color2[2] = 0.4; - l->color2[3] = 1.0; - -//Reflection degree of light - l->ambient[0] = 0.4; - l->ambient[1] = 0.4; - l->ambient[2] = 0.4; - l->ambient[3] = 1.0; - -} - -// 自作:miya -void ps2_vu0_normal_light_matrix(FMATRIX light_color, FVECTOR l0, FVECTOR l1, FVECTOR l2) -{ - char *miyahira; - miyahira = "この関数なに?"; -} - -// 自作:miya -void ps2_vu0_light_color_matrix( FMATRIX light_color, FVECTOR c0, FVECTOR c1, FVECTOR c2, FVECTOR a) -{ - char *miyahira; - miyahira = "test"; -} - -void set_light(LIGHT *l) -{ - ps2_vu0_normal_light_matrix(normal_light, l->light0, l->light1, l->light2); - ps2_vu0_light_color_matrix(light_color, l->color0, l->color1, l->color2, l->ambient); -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/light.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,77 @@ +/* light.c */ + +#include <stdio.h> +#include "libps2.h" +#include "light.h" + +#include "sjoy.h" // ps2関連ファイルから + +FMATRIX normal_light; +FMATRIX light_color; + + +void init_light(LIGHT *l) +{ + //Three lights in all. + // The color of the light of "light0" is color0. + // The color of the light of "light1" is color1. + // The color of the light of "light2" is color2. + + + l->light0[0] = 0.0; + l->light0[1] = 0.0; + l->light0[2] = 1.0; + l->light0[3] = 1.0; + + l->light1[0] = 0.0; + l->light1[1] = -1.0; + l->light1[2] = 0.0; + l->light1[3] = 1.0; + + l->light2[0] = 1.0; + l->light2[1] = 1.0; + l->light2[2] = 1.0; + l->light2[3] = 1.0; + + l->color0[0] = 0.4; + l->color0[1] = 0.4; + l->color0[2] = 0.4; + l->color0[3] = 1.0; + + l->color1[0] = 0.4; + l->color1[1] = 0.4; + l->color1[2] = 0.4; + l->color1[3] = 1.0; + + l->color2[0] = 0.4; + l->color2[1] = 0.4; + l->color2[2] = 0.4; + l->color2[3] = 1.0; + +//Reflection degree of light + l->ambient[0] = 0.4; + l->ambient[1] = 0.4; + l->ambient[2] = 0.4; + l->ambient[3] = 1.0; + +} + +// 自作:miya +void ps2_vu0_normal_light_matrix(FMATRIX light_color, FVECTOR l0, FVECTOR l1, FVECTOR l2) +{ + char *miyahira; + miyahira = "この関数なに?"; +} + +// 自作:miya +void ps2_vu0_light_color_matrix( FMATRIX light_color, FVECTOR c0, FVECTOR c1, FVECTOR c2, FVECTOR a) +{ + char *miyahira; + miyahira = "test"; +} + +void set_light(LIGHT *l) +{ + ps2_vu0_normal_light_matrix(normal_light, l->light0, l->light1, l->light2); + ps2_vu0_light_color_matrix(light_color, l->color0, l->color1, l->color2, l->ambient); +}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/linda.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,729 @@ +#include <stdio.h> +#include <stdlib.h> +#include <stdbool.h> +#include <string.h> +#include <math.h> +#include <arpa/inet.h> +#include "libps2.h" +#include "ps2util.h" + +#include "car.h" +#include "game.h" +#include "Linda/lindaapi.h" +#include "linda.h" + +extern void psx_free(unsigned char *); +extern void carNode_append(CarPtr); +extern FILE *main_fp; +static int my_id; +static CarPtr linda_carlist[CLIENT_MAX+1]; +static int linda_seq[CLIENT_MAX+1]; + +static bool (*sche_func)(int); + +static void +set_header(unsigned int data, char *pkt, int offset) +{ + int *ipkt; + int ndata = htonl(data); + + ipkt = (int*)pkt; + ipkt[offset/4] = ndata; +} + +static unsigned int +get_header(char *pkt, int offset) +{ + int *ipkt; + int data; + unsigned int header; + + ipkt = (int *)pkt; + data = ipkt[offset/4]; + header = (unsigned int)ntohl(data); + + return header; +} + +static char* +make_packet(unsigned int mode, unsigned int carid, + unsigned int courseid, char *data) +{ + char *packet; + unsigned int len = 0; + + if (data) len += sizeof(FMATRIX); + + packet = (char*)malloc(PKT_HEADER_SIZE+len); + + set_header(mode, packet, PKT_MODE_OFFSET); + set_header(carid, packet, PKT_CARID_OFFSET); + set_header(courseid, packet, PKT_COURSEID_OFFSET); + + if (data) + memcpy(packet+PKT_DATA_OFFSET, data, len); + + return packet; +} + + +static void +send_packet(unsigned int dest, unsigned int mode, unsigned int car, + unsigned int course, char *data) +{ + char *pkt; + char *reply; + int len = PKT_HEADER_SIZE; + + if (data) len += sizeof(FMATRIX); + + reply = psx_reply(linda_seq[dest]); + + if (linda_seq[dest] == 0) { + pkt = make_packet(mode, car, course, data); + psx_out(dest, pkt, len); + free(pkt); + } else if (reply = psx_reply(linda_seq[dest])) { + pkt = make_packet(mode, car, course, data); + psx_out(dest, pkt, len); + free(pkt); + psx_free(reply); + } + + pkt = make_packet(mode, car, course, data); + psx_out(dest, pkt, len); + free(pkt); +} + +static void +get_packet(int id, int *flg, int *mode, int *car, int *course, char *data) +{ + char *reply = NULL; + char *pkt = NULL; + + reply = psx_reply(linda_seq[id]); + if (reply) { + pkt = reply+LINDA_HEADER_SIZE; + + if (flg) *flg = 1; + if (mode) *mode = get_header(pkt, PKT_MODE_OFFSET); + if (car) *car = get_header(pkt, PKT_CARID_OFFSET); + if (course) *course = get_header(pkt, PKT_COURSEID_OFFSET); + if (data) memcpy(data, pkt+PKT_DATA_OFFSET, sizeof(FMATRIX)); + psx_free(reply); + linda_seq[id] = psx_rd(id); + } +} + +static void +linda_set_schedule(void *func, int mode, Game *game) +{ + int id = game->play_id; + + linda_seq[id] = psx_in(id); + sche_func = func; + send_packet(id, mode, game->car_id, game->course_id, NULL); +} + +static bool linda_sche_wait0(int p, Game *game) +{ + int i, flg=0; + int mode = 0; + int id = game->play_id; + int connect = 1; // 接続済みユーザ数 + + for (i=1; i<=CLIENT_MAX; i++) { + if (i == id) continue; + get_packet(i, &flg, &mode, NULL, NULL, NULL); + if (flg == 1 && mode == MODE_WAIT) { + connect++; + flg = 0; + } + } + + if (p == 1 && connect == CLIENT_MAX) { + linda_set_schedule(linda_sche_wait_ready0, MODE_WAIT_READY,game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_wait1(int p, Game *game) +{ + int mode; + + get_packet(PLAYER_1P, NULL, &mode, NULL, NULL, NULL); + + if (mode == MODE_WAIT_READY) { + linda_set_schedule(linda_sche_wait_ready1, MODE_WAIT_READY, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_wait_ready0(int p, Game *game) +{ + int i, flg, mode; + int id = game->play_id; + int connect = 1; + + for (i=1; i<=CLIENT_MAX; i++) { + if (i == id) continue; + get_packet(i, &flg, &mode, NULL, NULL, NULL); + if (i == id) { + flg = 0; + continue; + } + if (flg == 1 && mode == MODE_WAIT_READY) { + connect++; + flg = 0; + } + } + + if (p == 1 && connect == CLIENT_MAX) { + linda_set_schedule(linda_sche_opening0, MODE_OPENING,game); + return true; + } else { + return false; + } + +} + +static bool +linda_sche_wait_ready1(int p, Game *game) +{ + int mode; + + get_packet(PLAYER_1P, NULL, &mode, NULL, NULL, NULL); + + if (mode == MODE_OPENING) { + linda_set_schedule(linda_sche_opening1, MODE_OPENING,game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_opening0(int p, Game *game) +{ + int i, flg, mode; + int id = game->play_id; + int connect = 1; + + for (i=1; i<=CLIENT_MAX; i++) { + if (i == id) continue; + get_packet(i, &flg, &mode, NULL, NULL, NULL); + if (flg == 1 && mode == MODE_OPENING) { + connect++; + flg = 0; + } + } + + if (p == 1 && connect == CLIENT_MAX) { + linda_set_schedule(linda_sche_select_car0, MODE_SELECT_CAR, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_opening1(int p, Game *game) +{ + int mode; + + get_packet(PLAYER_1P, NULL, &mode, NULL, NULL, NULL); + + if (mode == MODE_SELECT_CAR) { + linda_set_schedule(linda_sche_select_car1, MODE_SELECT_CAR, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_select_car0(int p, Game *game) +{ + int i, flg, mode; + int id = game->play_id; + int connect = 1; + + for (i=1; i<=CLIENT_MAX; i++) { + if (i == id) continue; + get_packet(i, &flg, &mode, NULL, NULL, NULL); + if (flg == 1 && mode == MODE_SELECT_CAR) { + connect++; + flg = 0; + } + } + + if (p == 1 && connect == CLIENT_MAX) { + linda_set_schedule(linda_sche_select_course0, MODE_SELECT_COURSE, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_select_car1(int p, Game *game) +{ + int mode; + + get_packet(PLAYER_1P, NULL, &mode, NULL, NULL, NULL); + + if (mode == MODE_SELECT_COURSE) { + linda_set_schedule(linda_sche_select_course1, MODE_SELECT_COURSE, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_select_course0(int p, Game *game) +{ + int i; + int flg, mode; + int connect = 1; + int id = game->play_id; + static int course_id = 1; + + if (course_id != game->course_id) { + course_id = game->course_id; + linda_seq[id] = psx_in(id); + send_packet(id, MODE_SELECT_COURSE, 0, course_id, NULL); + return false; + } + + for (i=1; i<=CLIENT_MAX; i++) { + if (i == id) continue; + get_packet(i, &flg, &mode, NULL, NULL, NULL); + if (flg == 1 && mode == MODE_SELECT_COURSE) { + connect++; + flg = 0; + } + + } + + if (p == 1 && connect == CLIENT_MAX) { + linda_set_schedule(linda_sche_ready0, MODE_READY, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_select_course1(int p, Game *game) +{ + int mode, course_id; + + get_packet(PLAYER_1P, NULL, &mode, NULL, &course_id, NULL); + + if (mode == MODE_SELECT_COURSE) { + game->course_id = course_id; + return false; + } else if (mode == MODE_READY) { + linda_set_schedule(linda_sche_ready1, MODE_READY, game); + return true; + } else { + return false; + } +} + + +static bool +linda_sche_ready0(int p, Game *game) +{ + int i, flg, mode; + int id = game->play_id; + int connect = 1; + + for (i=1; i<=CLIENT_MAX; i++) { + if (i == id) continue; + get_packet(i, &flg, &mode, NULL, NULL, NULL); + if (flg == 1 && mode == MODE_READY) { + connect++; + flg = 0; + } + } + + if (p == 1 && connect == CLIENT_MAX) { + linda_set_schedule(linda_sche_main_init, MODE_MAIN_INIT, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_ready1(int p, Game *game) +{ + int mode; + + get_packet(PLAYER_1P, NULL, &mode, NULL, NULL, NULL); + + if (mode == MODE_MAIN_INIT) { + linda_set_schedule(linda_sche_main_init, MODE_MAIN_INIT, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_main_init(int p, Game *game) +{ + int i, flg, mode, car_id; + int id = game->play_id; + int connect = 1; + CarPtr car = NULL; + + for (i=1; i<=CLIENT_MAX; i++) { + if (i == id) continue; + get_packet(i, &flg, &mode, &car_id, NULL, NULL); + + if (flg == 1 && mode == MODE_MAIN_INIT) { + if (linda_carlist[i] == NULL) { + car = car_init(car_id); + carNode_append(car); + linda_carlist[i] = car; + } + connect++; + flg = 0; + } + } + + if (p == 1 && connect == CLIENT_MAX) { + if (id == PLAYER_1P) + linda_set_schedule(linda_sche_main_ready0, MODE_MAIN_READY, game); + else + linda_set_schedule(linda_sche_main_ready1, MODE_MAIN_READY, game); + return true; + } else { + return false; + } +} + + +static bool +linda_sche_main_ready0(int p, Game *game) +{ + int i, flg, mode; + int id = game->play_id; + int connect = 1; + + for (i=1; i<=CLIENT_MAX; i++) { + if (i == id) continue; + get_packet(i, &flg, &mode, NULL, NULL, NULL); + if (flg == 1 && mode == MODE_MAIN_READY) { + connect++; + flg = 0; + } + } + + if (p == 1 && connect == CLIENT_MAX) { + linda_set_schedule(linda_sche_main, MODE_MAIN, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_main_ready1(int p, Game *game) +{ + int mode; + + get_packet(PLAYER_1P, NULL, &mode, NULL, NULL, NULL); + + if (mode == MODE_MAIN) { + linda_set_schedule(linda_sche_main, MODE_MAIN, game); + return true; + } else { + return false; + } +} + +static bool +linda_sche_main(int p, Game *game) +{ + int i, flg, mode; + int id = game->play_id; + int connect = 1; + FMATRIX po; + CarPtr mycar = game->jiki; + CarPtr enemy = NULL; + + for (i=1; i<=CLIENT_MAX; i++) { + ps2_vu0_unit_matrix(po); + get_packet(i, &flg, &mode, NULL, NULL, (char*)po); + + if (i == id) { + ps2_vu0_copy_matrix(po, mycar->body->transfer); + ps2_vu0_copy_vector(po[3], mycar->location); + + linda_seq[i] = psx_in(i); + send_packet(i, MODE_MAIN, 0, 0, (char*)po); + } else { + enemy = linda_carlist[i]; + if (flg == 1 && mode == MODE_MAIN) { + ps2_vu0_copy_matrix(enemy->body->transfer, po); + enemy->body->transfer[3][0] -= mycar->location[0]; + enemy->body->transfer[3][1] -= mycar->location[1]; + enemy->body->transfer[3][2] -= mycar->location[2]; + enemy->body->transfer[3][3] = 1; + } + } + } + + if (p == 1 && connect == CLIENT_MAX) { + if (id == PLAYER_1P) + linda_set_schedule(linda_sche_main_ready0, MODE_MAIN_READY, game); + else + linda_set_schedule(linda_sche_main_ready1, MODE_MAIN_READY, game); + return true; + } else { + return false; + } + + + return false; +} + +bool +linda_update(int p, Game *game) +{ + return sche_func(p); +} + +#if 0 + +/* + * 位置が同じなら1を返す。 + * もっと良い比較方法があるんでは... + */ +static int +linda_jiki_compareLocation(Game *game) +{ + float x,y,z; + double d; + + if (common_state == GAME_MAIN || common_state == GAME_GOAL) { + x = jiki.position[3][0] - game.jiki->location[0]; + y = jiki.position[3][1] - game.jiki->location[1]; + z = jiki.position[3][2] - game.jiki->location[2]; + d = sqrt(x*x+y*y+z*z); + + if (d < 1.0) { + return 1; + } else { + return 0; + } + } else { + return 1; + } +} + + +/* + * 自機情報が更新されていなければ + * 0を返す(psx_outしない) + */ +static int +linda_jiki_compare() +{ + if ((jiki.car_id == game.car_id) && + (jiki.course_id == game.course_id) && + (jiki.create_flg == ((game.jiki) ? 1:0)) && + (jiki.state == common_state) && + (linda_jiki_compareLocation())) { + return 0; + } else { + return 1; + } +} + +static void +linda_jiki_update() +{ + int i,j; + + + jiki.car_id = game.car_id; + jiki.course_id = game.course_id; + jiki.create_flg = (game.jiki) ? 1 : 0; + jiki.state = common_state; + + if (common_state == GAME_MAIN || common_state == GAME_GOAL) { + for (i=0; i<3; i++) { + for (j=0; j<4; j++) { + jiki.position[i][j] + = game.jiki->body->transfer[i][j]; + } + } + jiki.position[3][0] = game.jiki->location[0]; + jiki.position[3][1] = game.jiki->location[1]; + jiki.position[3][2] = game.jiki->location[2]; + jiki.position[3][3] = 1; + } +} + +void +linda_update() +{ + int i; + int barrier = 1; // バリア同期(?)用 + int connect = 1; + int mode, id, flg; + char* reply; + char* pkt; + CarPtr car = NULL; + + for (i=1; i<=CLIENT_MAX; i++) { + reply = psx_reply(linda_seq[i]); + if (reply) { + pkt = reply+LINDA_HEADER_SIZE; + mode = get_header(pkt, PKT_MODE_OFFSET); + id = get_header(pkt, PKT_ID_OFFSET); + flg = get_header(pkt, PKT_FLG_OFFSET); + + if (i != game.play_id) { + connect++; + + car = linda_carlist[i]; + if (common_state == GAME_MAIN && !car && p->create_flg == 1) { + car = car_init(p->car_id); + carNode_append(car); + linda_carlist[i] = car; + } + linda_enemy_update(i, car, p); + if (common_state == p->state) { + barrier++; + } + } + psx_free(reply); + linda_seq[i] = psx_rd(i); + } + } + + if (connect == CLIENT_MAX) { + if (game->state == GAME_WAIT) { + gFont_SetString("CONNECT OK!!", 170, 300); + if (game->play_id == 1) + gFont_SetString(" PUSH START ", 170, 400); + } + + // ごちゃごちゃしてる... + // なんか無駄な処理がありそうだ + if (game->play_id == 1) { + // 全員のフラグ成立 + if (common_state == GAME_GOAL) { + if (game->state == GAME_FINISH) { + common_state = game->state; + } else { + game->state = common_state; + } + } else if (barrier == CLIENT_MAX) { + common_state = game->state; + } else { + game->state = common_state; + } + } else { + if (game->state == GAME_GOAL) { + if (common_state != GAME_FINISH) { + common_state = game->state; + } else { + game->state = common_state; + } + } else { + game->state = common_state; + } + } + } else { + if (game->state == GAME_WAIT) { + gFont_SetString("WAITING...", 200, 100); + } + game->state = common_state; + } + + if (linda_jiki_compare()) { +#ifdef DEBUG + // どのタイミングでoutされてるか見る + // 必要なときだけoutしないと重いですね当然だけど + fprintf(main_fp, "psx_out() jiki\n"); +#endif + linda_jiki_update(); + // 無理矢理 + // 古いものを消すだけなんだけど + // 正しいやり方が他に有るのかな? + // 実行し続けてると最終的に激重になるので + // ここら辺に問題が有るのだろうか。 + psx_free(psx_reply(psx_in(game->play_id))); + linda_seq[my_id]=psx_in(game->play_id); + psx_out(game->play_id, (char*)&jiki, sizeof(CarInfo)); + } +} +#endif + +static int +get_id() +{ + unsigned char * reply; + int seq; + int id; + + //ユーザIDが格納されているTUPLE SpaceのIDへアクセス + seq = psx_in(LINDA_ASK_ID); + + // IDが取得できるまでループ + while((reply = psx_reply(seq)) == 0) psx_sync_n(); + + id = atoi(reply+LINDA_HEADER_SIZE); + psx_free(reply); + return id; +} + +void linda_env_init( void ) +{ + int i; + + for (i=0; i<CLIENT_MAX+1; i++) { + linda_carlist[i] = NULL; + } +} + + + +int +linda_init(Game *game) +{ + int i; + + start_linda(LINDA_HOST); + my_id = get_id(); + + for (i=1; i<=CLIENT_MAX; i++) { + if (i == my_id) { + send_packet(i, MODE_WAIT, i, 0, NULL); + } + linda_seq[i] = psx_rd(i); + } + psx_sync_n(); + + if (my_id == PLAYER_1P) { + sche_func = &linda_sche_wait0; + } else { + sche_func = &linda_sche_wait1; + } + send_packet(game->play_id, MODE_WAIT, 1, 1, NULL); + + return my_id; +}
--- a/main.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,19 +0,0 @@ -#include <stdio.h> -#include "game.h" -#include "libps2.h" -#include "ps2util.h" - -FILE *main_fp; - -int -main(int argc, char* argv[]) -{ - main_fp = fopen("/dev/stdout", "w"); - if (!main_fp) { - perror("main"); - } - - game_main(); - ps2util_graphic_Finish(); - return 0; -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/main.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,19 @@ +#include <stdio.h> +#include "game.h" +#include "libps2.h" +#include "ps2util.h" + +FILE *main_fp; + +int +main(int argc, char* argv[]) +{ + main_fp = fopen("/dev/stdout", "w"); + if (!main_fp) { + perror("main"); + } + + game_main(); + ps2util_graphic_Finish(); + return 0; +}
--- a/mytype.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,54 +0,0 @@ -/* mytype.c */ - -#include <time.h> -#include <stdio.h> -#include <stdbool.h> -#include "libps2.h" -#include "ps2util.h" -#include "mytype.h" - -static clock_t start; -static clock_t race_start; - -void -wait_init() -{ - start = clock(); -} - -/* - * wait_init()から - * time秒(マイクロ秒?)すぎたらTRUEを返す - */ -bool -wait(double time) -{ - clock_t t; - double a; - - t = clock(); - a = (t-start)/(double)CLOCKS_PER_SEC; - if (a > time) { - return true; - } - - return false; -} - -void -time_RaceStart() -{ - race_start = clock(); -} - -double -time_RaceTime() -{ - clock_t t; - double a; - - t = clock(); - a = (t-race_start)/(double)CLOCKS_PER_SEC; - - return a; -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mytype.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,54 @@ +/* mytype.c */ + +#include <time.h> +#include <stdio.h> +#include <stdbool.h> +#include "libps2.h" +#include "ps2util.h" +#include "mytype.h" + +static clock_t start; +static clock_t race_start; + +void +wait_init() +{ + start = clock(); +} + +/* + * wait_init()から + * time秒(マイクロ秒?)すぎたらTRUEを返す + */ +bool +wait(double time) +{ + clock_t t; + double a; + + t = clock(); + a = (t-start)/(double)CLOCKS_PER_SEC; + if (a > time) { + return true; + } + + return false; +} + +void +time_RaceStart() +{ + race_start = clock(); +} + +double +time_RaceTime() +{ + clock_t t; + double a; + + t = clock(); + a = (t-race_start)/(double)CLOCKS_PER_SEC; + + return a; +}
--- a/ps2util.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,384 +0,0 @@ -/* ps2util.c */ - -#include <string.h> -#include <stdio.h> -#include <stdlib.h> -#include <math.h> -#include "libps2.h" -#include "ps2util.h" - -/* - たぶん、本当は読み込んだ xml file から情報を取得するとかそんなんだと思う - どんな処理か分からないので、とりあえず、初期化している。 -*/ - -OBJECT *ps2util_obj_Create_fromXML(char *filename) -{ - OBJECT *body; - - /* - body->xyz = {0,0,0,0}; - body->angle = {0,0,0,0}; - body->transfer = { {0,0,0,0}, {0,0,0,0}, {0,0,0,0}, {0,0,0,0} }; - body->*name = filename; - body->*free_me = NULL; - */ - - return body; -} - - - -void ps2util_obj_Set_effect(OBJECT *body, int def) -{ - //none -} - -// ベクトル v1 をベクトル v2 にコピーする -void ps2_vu0_copy_vector(FVECTOR directionA, FVECTOR directionB) -{ - memcpy(directionA, directionB, sizeof(FVECTOR)); -} - - -void ps2util_obj_Renew_transMatrix(OBJECT *car){ - //none -} - - -/* - ps2 内の texture.c から -*/ -TEXTURE* read_png_file(char *texname) -{ - printf("trace\n"); - //とりあえず戻り値を返してエラーをどうにか - TEXTURE* tex; - - return tex; -} - - - -int ps2util_tex_Set(TEXTURE* tex) -{ - return -1; -} - -int ps2util_sprite_Create(ps2utilSprite *Sp, TEXTURE *sprite_tex) -{ - return -1; -} - - -void ps2util_obj_Set_texture(OBJECT* car_body, TEXTURE *tex) -{ - //none -} - -// 与えられた行列を単位行列に変換する -void ps2_vu0_unit_matrix(FMATRIX m) -{ - m[0][1] = m[0][2] = m[0][3] = 0; - m[1][0] = m[1][2] = m[1][3] = 0; - m[2][0] = m[2][1] = m[2][3] = 0; - m[3][0] = m[3][1] = m[3][2] = 0; - m[0][0] = m[1][1] = m[2][2] = m[3][3] = 1.0; -} - -/* -Y軸を中心とした行列の回転 -回転角 rx より X 軸を中心とした回転マトリックスを求めて、マトリックス m1 に左側から乗算して、その結果をマトリックス m0 に与える。 -X 軸だけでなく Y 軸、Z 軸を中心とした関数もある。また3ついっんに回転させる関数もある。 -*/ -void ps2_vu0_rot_matrix_y(FMATRIX result, FMATRIX m, float radian) -{ - // 回転行列を作ってかけてやれば良い - - m[0][1] = m[0][2] = m[0][3] = 0; - m[1][0] = m[1][2] = m[1][3] = 0; - m[2][0] = m[2][1] = m[2][3] = 0; - m[3][0] = m[3][1] = m[3][2] = 0; - m[0][0] = m[1][1] = m[2][2] = m[3][3] = 1.0; - - - m[0][0] = sinf(radian); - m[2][2] = sinf(radian); - m[0][2] = -cosf(radian); - m[2][0] = cosf(radian); - - FMATRIX m1;// = m; - memcpy(&m1, m, sizeof(FMATRIX)); - - ps2_vu0_mul_matrix(result, m1, m); -} - -// ベクトルの計算 -// マトリックス m にベクトル を右から乗算して result に与える -void ps2_vu0_apply_matrix(FVECTOR result, FMATRIX m, FVECTOR v) -{ - result[0] = m[0][0] * v[0] + m[0][1] * v[1] + m[0][2] * v[2] + m[0][3] * v[3] ; - result[1] = m[1][0] * v[0] + m[1][1] * v[1] + m[1][2] * v[2] + m[1][3] * v[3] ; - result[2] = m[2][0] * v[0] + m[2][1] * v[1] + m[2][2] * v[2] + m[2][3] * v[3] ; - result[3] = m[3][0] * v[0] + m[3][1] * v[1] + m[3][2] * v[2] + m[3][3] * v[3] ; -} - - -void ps2_vu0_scale_vector(FVECTOR mov, FVECTOR car_direction, float car_speed) -{ - mov[0] = car_direction[0] * car_speed ; - mov[1] = car_direction[1] * car_speed ; - mov[2] = car_direction[2] * car_speed ; - mov[3] = car_direction[3]; -} - -// ベクトル v1 の各要素とベクトル v2 の各要素を各々加算してv0に与える -// v0 = v1+v2 -void ps2_vu0_add_vector(FVECTOR result, FVECTOR v0, FVECTOR v1) -{ - result[0] = v0[0] + v1[0]; - result[1] = v0[1] + v1[1]; - result[2] = v0[2] + v1[2]; - // result[3] = v0[3] + v1[3]; - result[3] = v0[3]; -} - -// 外積 -void ps2_vu0_outer_product(FVECTOR result, FVECTOR v0, FVECTOR v1) -{ - result[0] = v0[1] * v1[2] - v0[2] * v1[1] ; - result[1] = v0[0] * v1[2] - v0[2] * v1[0] ; - result[2] = v0[0] * v1[1] - v0[1] * v1[0] ; - result[3] = 1; -} - -// 内積 -float ps2_vu0_inner_product(FVECTOR v0, FVECTOR v1) -{ - return v0[0] * v1[0] + v0[1] * v1[1] + v0[2] * v1[2]; -} - - -void ps2_vu0_mul_matrix(FMATRIX result, FMATRIX m0, FMATRIX m1) -{ - result[0][0] = m0[0][0] * m1[0][0] + m0[0][1] * m1[1][0] + m0[0][2] * m1[2][0] + m0[0][3] * m1[3][0]; - result[0][1] = m0[0][0] * m1[0][1] + m0[0][1] * m1[1][1] + m0[0][2] * m1[2][1] + m0[0][3] * m1[3][1]; - result[0][2] = m0[0][0] * m1[0][2] + m0[0][1] * m1[1][2] + m0[0][2] * m1[2][2] + m0[0][3] * m1[3][2]; - result[0][3] = m0[0][0] * m1[0][3] + m0[0][1] * m1[1][3] + m0[0][2] * m1[2][3] + m0[0][3] * m1[3][3]; - - result[1][0] = m0[1][0] * m1[0][0] + m0[1][1] * m1[1][0] + m0[1][2] * m1[2][0] + m0[1][3] * m1[3][0]; - result[1][1] = m0[1][0] * m1[0][1] + m0[1][1] * m1[1][1] + m0[1][2] * m1[2][1] + m0[1][3] * m1[3][1]; - result[1][2] = m0[1][0] * m1[0][2] + m0[1][1] * m1[1][2] + m0[1][2] * m1[2][2] + m0[1][3] * m1[3][2]; - result[1][3] = m0[1][0] * m1[0][3] + m0[1][1] * m1[1][3] + m0[1][2] * m1[2][3] + m0[1][3] * m1[3][3]; - - result[2][0] = m0[2][0] * m1[0][0] + m0[2][1] * m1[1][0] + m0[2][2] * m1[2][0] + m0[2][3] * m1[3][0]; - result[2][1] = m0[2][0] * m1[0][1] + m0[2][1] * m1[1][1] + m0[2][2] * m1[2][1] + m0[2][3] * m1[3][1]; - result[2][2] = m0[2][0] * m1[0][2] + m0[2][1] * m1[1][2] + m0[2][2] * m1[2][2] + m0[2][3] * m1[3][2]; - result[2][3] = m0[2][0] * m1[0][3] + m0[2][1] * m1[1][3] + m0[2][2] * m1[2][3] + m0[2][3] * m1[3][3]; - - result[3][0] = m0[3][0] * m1[0][0] + m0[3][1] * m1[1][0] + m0[3][2] * m1[2][0] + m0[3][3] * m1[3][0]; - result[3][1] = m0[3][0] * m1[0][1] + m0[3][1] * m1[1][1] + m0[3][2] * m1[2][1] + m0[3][3] * m1[3][1]; - result[3][2] = m0[3][0] * m1[0][2] + m0[3][1] * m1[1][2] + m0[3][2] * m1[2][2] + m0[3][3] * m1[3][2]; - result[3][3] = m0[3][0] * m1[0][3] + m0[3][1] * m1[1][3] + m0[3][2] * m1[2][3] + m0[3][3] * m1[3][3]; -} - - -void ps2_vu0_copy_matrix(FMATRIX transfer, FMATRIX pose) -{ - memcpy(transfer, pose, sizeof(FMATRIX)); -} - -void ps2util_obj_Free(OBJECT* obj) -{ - free(obj); -} - - - -void ps2_vu0_sub_vector(FVECTOR result, FVECTOR v0, FVECTOR v1) -{ - result[0] = v0[0] - v1[0]; - result[1] = v0[1] - v1[1]; - result[2] = v0[2] - v1[2]; - result[3] = v0[3];// - v1[3]; -} - - - -void ps2_vu0_normalize(FVECTOR result, FVECTOR v) -{ - // 大きさで割ってるだけって - float d = sqrtf(v[0] * v[0] + v[1] * v[1] + v[2] * v[2]); - result[0] = v[0] / d; - result[1] = v[1] / d; - result[2] = v[2] / d; - result[3] = 1; -} - - -void xml_free(PolygonInfo xml) -{ - //none -} - - -void ps2util_obj_Draw(OBJECT *object) -{ - //none -} - - -void ps2util_sprite_Destroy(ps2utilSprite *title_sprite ) -{ - //none -} - - - - -void ps2util_sprite_Set_basicAttribute(ps2utilSprite *p, - unsigned short x, unsigned short y, - unsigned short sptable_tw1, unsigned short sptable_th1, - unsigned short sptable_tx, unsigned short sptable_ty, - unsigned short sptable_tw2, unsigned short sptable_th2, - int sprite_prio_foreground) -{ - //none -} - -void ps2util_sprite_Request(ps2utilSprite *p) -{ - //none -} - - -void ps2util_sprite_Unuse_alpha(ps2utilSprite *sp) -{ - //none -} - -void ps2util_graphic_Init() -{ - //none -} - - -/* - ps2 依存関係の sprite.c より引用。 -*/ -#define SPRITE_HAS_4VERTEXIS 4 - -#define PS2_GS_XYZ3 1 // なにかわからん定数だから適当に作りました - -void -sprite_disappear( SPRITE* sprite ) -{ - int i; - GsSpritePacket* packet = sprite->gs_packet; - for (i=0; i<SPRITE_HAS_4VERTEXIS; i++) - packet->primData[i].xyz_addr = PS2_GS_XYZ3; -} - - - - -/* - からの関数 - ps2 依存関係にあったけど、( name_dictionary.c ) の中のもの - だけど、他にも持ってくるものが増えるので、とりあえず、からの関数に -*/ -void delete_name_dictionary(const char *string) -{ - /* - int number; - NAME_DIC *dic_ptr; - - if (string == NULL) return; - - number = hash_func(string,NAME_HASH_SIZE); - - for (dic_ptr=name_hash+number;dic_ptr->name;dic_ptr=name_hash+number) { - if (!strcmp(string,dic_ptr->name)) { - dic_ptr->ref_num--; - if (dic_ptr->ref_num == 0) { - free(dic_ptr->name); - dic_ptr->name = NULL; - } - return; - } else { - number += REHASH_NUM; - if (number > NAME_HASH_SIZE) number -= NAME_HASH_SIZE; - } - } - */ -} - - - -/* - ps2 依存関係から持ってきた。 - テクスチャに割り振ったメモリの解放処理? - 元ファイル:texture.c -*/ -void free_texture(TEXTURE *tex) -{ - if (tex == NULL) return; - - delete_name_dictionary(tex->name); - free(tex->free_texenv); - free(tex->free_image); - free(tex); -} - - -/* - ps2 依存関係内の、texture.c から拝借 - この malloc によるメモリ取得をあちこちで行っているっぽい - cerium にある。 -*/ -int malloc_align16(void *free, void *aligned, int size) -{ - char *index; - unsigned int *f=(unsigned int *)free,*a=(unsigned int *)aligned; - - if (free == NULL || aligned == NULL || size <= 0) return(-1); - - index = (char *)malloc(size + ALIGN_16BYTE); - if (index == NULL) { - return(-1); - } - - *f = *a = (unsigned long int)index; - if (((unsigned long int)index % ALIGN_16BYTE) != 0) { - index += ALIGN_16BYTE - ((unsigned long int)index % ALIGN_16BYTE); - *a = (unsigned long int)index; - } - - return(0); -} - - - -// miya -void ps2util_tex_Exclude( TEXTURE* t ) -{ - char *miyahira; - miyahira = "なにこの関数?"; -} - -void ps2util_sprite_Draw() -{ - printf("ps2util_sprite_Draw()\n"); -} - -void ps2util_graphic_Finish() -{ - printf("ps2util_graphic_Finish()\n"); -} - - -// title.cに書いてた -void ps2util_sprite_Use_alpha( ps2utilSprite *title ) -{ - printf("ps2util_sprite_Use_alpha()\n"); -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/ps2util.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,384 @@ +/* ps2util.c */ + +#include <string.h> +#include <stdio.h> +#include <stdlib.h> +#include <math.h> +#include "libps2.h" +#include "ps2util.h" + +/* + たぶん、本当は読み込んだ xml file から情報を取得するとかそんなんだと思う + どんな処理か分からないので、とりあえず、初期化している。 +*/ + +OBJECT *ps2util_obj_Create_fromXML(char *filename) +{ + OBJECT *body; + + /* + body->xyz = {0,0,0,0}; + body->angle = {0,0,0,0}; + body->transfer = { {0,0,0,0}, {0,0,0,0}, {0,0,0,0}, {0,0,0,0} }; + body->*name = filename; + body->*free_me = NULL; + */ + + return body; +} + + + +void ps2util_obj_Set_effect(OBJECT *body, int def) +{ + //none +} + +// ベクトル v1 をベクトル v2 にコピーする +void ps2_vu0_copy_vector(FVECTOR directionA, FVECTOR directionB) +{ + memcpy(directionA, directionB, sizeof(FVECTOR)); +} + + +void ps2util_obj_Renew_transMatrix(OBJECT *car){ + //none +} + + +/* + ps2 内の texture.c から +*/ +TEXTURE* read_png_file(char *texname) +{ + printf("trace\n"); + //とりあえず戻り値を返してエラーをどうにか + TEXTURE* tex; + + return tex; +} + + + +int ps2util_tex_Set(TEXTURE* tex) +{ + return -1; +} + +int ps2util_sprite_Create(ps2utilSprite *Sp, TEXTURE *sprite_tex) +{ + return -1; +} + + +void ps2util_obj_Set_texture(OBJECT* car_body, TEXTURE *tex) +{ + //none +} + +// 与えられた行列を単位行列に変換する +void ps2_vu0_unit_matrix(FMATRIX m) +{ + m[0][1] = m[0][2] = m[0][3] = 0; + m[1][0] = m[1][2] = m[1][3] = 0; + m[2][0] = m[2][1] = m[2][3] = 0; + m[3][0] = m[3][1] = m[3][2] = 0; + m[0][0] = m[1][1] = m[2][2] = m[3][3] = 1.0; +} + +/* +Y軸を中心とした行列の回転 +回転角 rx より X 軸を中心とした回転マトリックスを求めて、マトリックス m1 に左側から乗算して、その結果をマトリックス m0 に与える。 +X 軸だけでなく Y 軸、Z 軸を中心とした関数もある。また3ついっんに回転させる関数もある。 +*/ +void ps2_vu0_rot_matrix_y(FMATRIX result, FMATRIX m, float radian) +{ + // 回転行列を作ってかけてやれば良い + + m[0][1] = m[0][2] = m[0][3] = 0; + m[1][0] = m[1][2] = m[1][3] = 0; + m[2][0] = m[2][1] = m[2][3] = 0; + m[3][0] = m[3][1] = m[3][2] = 0; + m[0][0] = m[1][1] = m[2][2] = m[3][3] = 1.0; + + + m[0][0] = sinf(radian); + m[2][2] = sinf(radian); + m[0][2] = -cosf(radian); + m[2][0] = cosf(radian); + + FMATRIX m1;// = m; + memcpy(&m1, m, sizeof(FMATRIX)); + + ps2_vu0_mul_matrix(result, m1, m); +} + +// ベクトルの計算 +// マトリックス m にベクトル を右から乗算して result に与える +void ps2_vu0_apply_matrix(FVECTOR result, FMATRIX m, FVECTOR v) +{ + result[0] = m[0][0] * v[0] + m[0][1] * v[1] + m[0][2] * v[2] + m[0][3] * v[3] ; + result[1] = m[1][0] * v[0] + m[1][1] * v[1] + m[1][2] * v[2] + m[1][3] * v[3] ; + result[2] = m[2][0] * v[0] + m[2][1] * v[1] + m[2][2] * v[2] + m[2][3] * v[3] ; + result[3] = m[3][0] * v[0] + m[3][1] * v[1] + m[3][2] * v[2] + m[3][3] * v[3] ; +} + + +void ps2_vu0_scale_vector(FVECTOR mov, FVECTOR car_direction, float car_speed) +{ + mov[0] = car_direction[0] * car_speed ; + mov[1] = car_direction[1] * car_speed ; + mov[2] = car_direction[2] * car_speed ; + mov[3] = car_direction[3]; +} + +// ベクトル v1 の各要素とベクトル v2 の各要素を各々加算してv0に与える +// v0 = v1+v2 +void ps2_vu0_add_vector(FVECTOR result, FVECTOR v0, FVECTOR v1) +{ + result[0] = v0[0] + v1[0]; + result[1] = v0[1] + v1[1]; + result[2] = v0[2] + v1[2]; + // result[3] = v0[3] + v1[3]; + result[3] = v0[3]; +} + +// 外積 +void ps2_vu0_outer_product(FVECTOR result, FVECTOR v0, FVECTOR v1) +{ + result[0] = v0[1] * v1[2] - v0[2] * v1[1] ; + result[1] = v0[0] * v1[2] - v0[2] * v1[0] ; + result[2] = v0[0] * v1[1] - v0[1] * v1[0] ; + result[3] = 1; +} + +// 内積 +float ps2_vu0_inner_product(FVECTOR v0, FVECTOR v1) +{ + return v0[0] * v1[0] + v0[1] * v1[1] + v0[2] * v1[2]; +} + + +void ps2_vu0_mul_matrix(FMATRIX result, FMATRIX m0, FMATRIX m1) +{ + result[0][0] = m0[0][0] * m1[0][0] + m0[0][1] * m1[1][0] + m0[0][2] * m1[2][0] + m0[0][3] * m1[3][0]; + result[0][1] = m0[0][0] * m1[0][1] + m0[0][1] * m1[1][1] + m0[0][2] * m1[2][1] + m0[0][3] * m1[3][1]; + result[0][2] = m0[0][0] * m1[0][2] + m0[0][1] * m1[1][2] + m0[0][2] * m1[2][2] + m0[0][3] * m1[3][2]; + result[0][3] = m0[0][0] * m1[0][3] + m0[0][1] * m1[1][3] + m0[0][2] * m1[2][3] + m0[0][3] * m1[3][3]; + + result[1][0] = m0[1][0] * m1[0][0] + m0[1][1] * m1[1][0] + m0[1][2] * m1[2][0] + m0[1][3] * m1[3][0]; + result[1][1] = m0[1][0] * m1[0][1] + m0[1][1] * m1[1][1] + m0[1][2] * m1[2][1] + m0[1][3] * m1[3][1]; + result[1][2] = m0[1][0] * m1[0][2] + m0[1][1] * m1[1][2] + m0[1][2] * m1[2][2] + m0[1][3] * m1[3][2]; + result[1][3] = m0[1][0] * m1[0][3] + m0[1][1] * m1[1][3] + m0[1][2] * m1[2][3] + m0[1][3] * m1[3][3]; + + result[2][0] = m0[2][0] * m1[0][0] + m0[2][1] * m1[1][0] + m0[2][2] * m1[2][0] + m0[2][3] * m1[3][0]; + result[2][1] = m0[2][0] * m1[0][1] + m0[2][1] * m1[1][1] + m0[2][2] * m1[2][1] + m0[2][3] * m1[3][1]; + result[2][2] = m0[2][0] * m1[0][2] + m0[2][1] * m1[1][2] + m0[2][2] * m1[2][2] + m0[2][3] * m1[3][2]; + result[2][3] = m0[2][0] * m1[0][3] + m0[2][1] * m1[1][3] + m0[2][2] * m1[2][3] + m0[2][3] * m1[3][3]; + + result[3][0] = m0[3][0] * m1[0][0] + m0[3][1] * m1[1][0] + m0[3][2] * m1[2][0] + m0[3][3] * m1[3][0]; + result[3][1] = m0[3][0] * m1[0][1] + m0[3][1] * m1[1][1] + m0[3][2] * m1[2][1] + m0[3][3] * m1[3][1]; + result[3][2] = m0[3][0] * m1[0][2] + m0[3][1] * m1[1][2] + m0[3][2] * m1[2][2] + m0[3][3] * m1[3][2]; + result[3][3] = m0[3][0] * m1[0][3] + m0[3][1] * m1[1][3] + m0[3][2] * m1[2][3] + m0[3][3] * m1[3][3]; +} + + +void ps2_vu0_copy_matrix(FMATRIX transfer, FMATRIX pose) +{ + memcpy(transfer, pose, sizeof(FMATRIX)); +} + +void ps2util_obj_Free(OBJECT* obj) +{ + free(obj); +} + + + +void ps2_vu0_sub_vector(FVECTOR result, FVECTOR v0, FVECTOR v1) +{ + result[0] = v0[0] - v1[0]; + result[1] = v0[1] - v1[1]; + result[2] = v0[2] - v1[2]; + result[3] = v0[3];// - v1[3]; +} + + + +void ps2_vu0_normalize(FVECTOR result, FVECTOR v) +{ + // 大きさで割ってるだけって + float d = sqrtf(v[0] * v[0] + v[1] * v[1] + v[2] * v[2]); + result[0] = v[0] / d; + result[1] = v[1] / d; + result[2] = v[2] / d; + result[3] = 1; +} + + +void xml_free(PolygonInfo xml) +{ + //none +} + + +void ps2util_obj_Draw(OBJECT *object) +{ + //none +} + + +void ps2util_sprite_Destroy(ps2utilSprite *title_sprite ) +{ + //none +} + + + + +void ps2util_sprite_Set_basicAttribute(ps2utilSprite *p, + unsigned short x, unsigned short y, + unsigned short sptable_tw1, unsigned short sptable_th1, + unsigned short sptable_tx, unsigned short sptable_ty, + unsigned short sptable_tw2, unsigned short sptable_th2, + int sprite_prio_foreground) +{ + //none +} + +void ps2util_sprite_Request(ps2utilSprite *p) +{ + //none +} + + +void ps2util_sprite_Unuse_alpha(ps2utilSprite *sp) +{ + //none +} + +void ps2util_graphic_Init() +{ + //none +} + + +/* + ps2 依存関係の sprite.c より引用。 +*/ +#define SPRITE_HAS_4VERTEXIS 4 + +#define PS2_GS_XYZ3 1 // なにかわからん定数だから適当に作りました + +void +sprite_disappear( SPRITE* sprite ) +{ + int i; + GsSpritePacket* packet = sprite->gs_packet; + for (i=0; i<SPRITE_HAS_4VERTEXIS; i++) + packet->primData[i].xyz_addr = PS2_GS_XYZ3; +} + + + + +/* + からの関数 + ps2 依存関係にあったけど、( name_dictionary.c ) の中のもの + だけど、他にも持ってくるものが増えるので、とりあえず、からの関数に +*/ +void delete_name_dictionary(const char *string) +{ + /* + int number; + NAME_DIC *dic_ptr; + + if (string == NULL) return; + + number = hash_func(string,NAME_HASH_SIZE); + + for (dic_ptr=name_hash+number;dic_ptr->name;dic_ptr=name_hash+number) { + if (!strcmp(string,dic_ptr->name)) { + dic_ptr->ref_num--; + if (dic_ptr->ref_num == 0) { + free(dic_ptr->name); + dic_ptr->name = NULL; + } + return; + } else { + number += REHASH_NUM; + if (number > NAME_HASH_SIZE) number -= NAME_HASH_SIZE; + } + } + */ +} + + + +/* + ps2 依存関係から持ってきた。 + テクスチャに割り振ったメモリの解放処理? + 元ファイル:texture.c +*/ +void free_texture(TEXTURE *tex) +{ + if (tex == NULL) return; + + delete_name_dictionary(tex->name); + free(tex->free_texenv); + free(tex->free_image); + free(tex); +} + + +/* + ps2 依存関係内の、texture.c から拝借 + この malloc によるメモリ取得をあちこちで行っているっぽい + cerium にある。 +*/ +int malloc_align16(void *free, void *aligned, int size) +{ + char *index; + unsigned int *f=(unsigned int *)free,*a=(unsigned int *)aligned; + + if (free == NULL || aligned == NULL || size <= 0) return(-1); + + index = (char *)malloc(size + ALIGN_16BYTE); + if (index == NULL) { + return(-1); + } + + *f = *a = (unsigned long int)index; + if (((unsigned long int)index % ALIGN_16BYTE) != 0) { + index += ALIGN_16BYTE - ((unsigned long int)index % ALIGN_16BYTE); + *a = (unsigned long int)index; + } + + return(0); +} + + + +// miya +void ps2util_tex_Exclude( TEXTURE* t ) +{ + char *miyahira; + miyahira = "なにこの関数?"; +} + +void ps2util_sprite_Draw() +{ + printf("ps2util_sprite_Draw()\n"); +} + +void ps2util_graphic_Finish() +{ + printf("ps2util_graphic_Finish()\n"); +} + + +// title.cに書いてた +void ps2util_sprite_Use_alpha( ps2utilSprite *title ) +{ + printf("ps2util_sprite_Use_alpha()\n"); +}
--- a/quotanion.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,53 +0,0 @@ -#include"libps2.h" -#include<math.h> -#include"mytype.h" - -/*--------------------------- - クォータニオンを求める - axis : 回転軸方向の単位ベクトル - angle : 回転量 - ---------------------------*/ -void -quotanion(FVECTOR q, FVECTOR axis, float angle) -{ - float s=sin(angle/2); - q[0] = axis[0]*s; - q[1] = axis[1]*s; - q[2] = axis[2]*s; - q[3] = cos(angle/2); -} - -/*----------------------- - クォータニオンqから - 変換行列rotを生成する - -----------------------*/ -void -quotanion_rotmatrix(FMATRIX rot, FVECTOR q) -{ - rot[0][0] = q[3]*q[3] + q[0]*q[0] - q[1]*q[1] - q[2]*q[2]; - rot[0][1] = 2*(q[0]*q[1] - q[3]*q[2]); - rot[0][2] = 2*(q[0]*q[2] + q[3]*q[1]); - rot[0][3] = 0; - rot[1][0] = 2*(q[0]*q[1] + q[3]*q[2]); - rot[1][1] = q[3]*q[3] - q[0]*q[0] + q[1]*q[1] - q[2]*q[2]; - rot[1][2] = 2*(q[1]*q[2] - q[3]*q[0]); - rot[1][3] = 0; - rot[2][0] = 2*(q[0]*q[2] - q[3]*q[1]); - rot[2][1] = 2*(q[1]*q[2] + q[3]*q[0]); - rot[2][2] = q[3]*q[3] - q[0]*q[0] - q[1]*q[1] + q[2]*q[2]; - rot[2][3] = 0; - rot[3][0] = 0; - rot[3][1] = 0; - rot[3][2] = 0; - rot[3][3] = 1; - -} - -float -degree2radian(float digree) -{ - float radian = digree * M_PI/180.0; - radian += (radian < -M_PI) ? 2*M_PI : 0; - radian += (radian > M_PI) ? -2*M_PI : 0; - return radian; -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/quotanion.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,53 @@ +#include"libps2.h" +#include<math.h> +#include"mytype.h" + +/*--------------------------- + クォータニオンを求める + axis : 回転軸方向の単位ベクトル + angle : 回転量 + ---------------------------*/ +void +quotanion(FVECTOR q, FVECTOR axis, float angle) +{ + float s=sin(angle/2); + q[0] = axis[0]*s; + q[1] = axis[1]*s; + q[2] = axis[2]*s; + q[3] = cos(angle/2); +} + +/*----------------------- + クォータニオンqから + 変換行列rotを生成する + -----------------------*/ +void +quotanion_rotmatrix(FMATRIX rot, FVECTOR q) +{ + rot[0][0] = q[3]*q[3] + q[0]*q[0] - q[1]*q[1] - q[2]*q[2]; + rot[0][1] = 2*(q[0]*q[1] - q[3]*q[2]); + rot[0][2] = 2*(q[0]*q[2] + q[3]*q[1]); + rot[0][3] = 0; + rot[1][0] = 2*(q[0]*q[1] + q[3]*q[2]); + rot[1][1] = q[3]*q[3] - q[0]*q[0] + q[1]*q[1] - q[2]*q[2]; + rot[1][2] = 2*(q[1]*q[2] - q[3]*q[0]); + rot[1][3] = 0; + rot[2][0] = 2*(q[0]*q[2] - q[3]*q[1]); + rot[2][1] = 2*(q[1]*q[2] + q[3]*q[0]); + rot[2][2] = q[3]*q[3] - q[0]*q[0] - q[1]*q[1] + q[2]*q[2]; + rot[2][3] = 0; + rot[3][0] = 0; + rot[3][1] = 0; + rot[3][2] = 0; + rot[3][3] = 1; + +} + +float +degree2radian(float digree) +{ + float radian = digree * M_PI/180.0; + radian += (radian < -M_PI) ? 2*M_PI : 0; + radian += (radian > M_PI) ? -2*M_PI : 0; + return radian; +}
--- a/schedule.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,512 +0,0 @@ -/* schedule.c */ - -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <stdbool.h> -#include "libps2.h" -#include "ps2util.h" -#include "field.h" -#include "car.h" -#include "gSprite.h" -#include "gFont.h" -#include "game.h" -#include "controler.h" -#include "camera.h" -#include "carNode.h" -#include "light.h" -#include "title_scene.h" -#include "game_time.h" -#include "schedule.h" -#include "game.h" - -#include "mytype.h" -#include "linda.h" - -#include "sjoy.h" - -#ifdef LINDA -bool linda_update(int p, Game *game); -#else -#define linda_update(change_state, game) true -#endif - -#define MAXCAR 3 // 選択可能機体 -#define MAXFIELD 2 // 選択可能コース -#define MAXRAP 3 // ラップ数 -#define SP_SEL_CAR 50 -#define SP_SEL_COURSE 80 - -// controler.cより -extern SGO_PAD pad; - - -static void set_schedule(Game *game); -static void sche_game_init(Game *game); -//static void sche_game_wait(Game *game); //プロトタイプも消しといた -//static void sche_game_wait_ready(Game *game); -static void sche_game_opening(Game *game); -static void sche_game_select_car(Game *game); -static void sche_game_select_course(Game *game); -static void sche_game_ready(Game *game); -static void sche_game_main_init(Game *game); -static void sche_game_main_ready(Game *game); -static void sche_game_main(Game *game); -static void sche_game_main_pause(Game *game); -static void sche_game_main_goal(Game *game); -static void sche_game_main_finish(Game *game); -static void sche_game_main_finish2(Game *game); - - - -/* timer */ -static int start_time,time_count; -static int RUNNIG=0; -char raptime[10]; - -static int ranking = 0; -static LIGHT l; -static int i=0; - -static void (*sche_func_assumption)(); -static void (*sche_func)() = &sche_game_init; -static int change_state = 0; - -// schedule.cで使用してる -void linda_env_init( void ); - -static void -set_schedule_assumption(void *_func) -{ - sche_func_assumption = _func; - change_state = 1; -} - -static void -unset_schedule() -{ - change_state = 0; -} - -static void -set_schedule(Game *game) -{ - sche_func = sche_func_assumption; - change_state = 0; -} - -static void -graphic_init() -{ - gSprite_Init(); // グラフィック関連の初期化 - gFont_Init(); // フォント関連の初期化 -} - -static void -play_init( Game *game ) -{ - game->jiki = car_init(game->car_id); - carNode_append(game->jiki); - field_init(game->course_id); -} - -// 適当に自作 :miya -void linda_env_init( void ) -{ - printf("linda_env_init\n"); -} - -static void game_env_init ( Game *game ) -{ - game->car_id = 1; - game->course_id = 1; - game->camera_type = 0; - game->rap = 1; - game->jiki = NULL; - - ranking = 0; - - wait_init(); - linda_env_init(); -} - - - -void -sche_game_init(Game *game) -{ - game_env_init(game); - graphic_init(); - camera_init(); - -#ifdef LINDA - //sche_func = &sche_game_wait; - //set_schedule_assumption(sche_game_wait); -#else - set_schedule_assumption(sche_game_opening); -#endif -} - -/** - * 通信対戦専用 - * 全ユーザが接続するまで待つ - * ・・・だったんだけど、現在 linda を切っているため worning が出る。 - * ので cut する。 - */ - -/* linda を使用しないのでカットした -static void -sche_game_wait(Game *game) -{ - gFont_SetString("WAITING...", 200, 100); - set_schedule_assumption(sche_game_wait_ready); -} -*/ - - -/** - * 通信対戦専用 - * 全ユーザの接続を確認したら呼び出す - * こいつも、linda がないので cut -*/ - /* -static void -sche_game_wait_ready(Game *game) -{ - gFont_SetString("CONNECT OK!!", 170, 300); - if (game->play_id == 1) { - gFont_SetString(" PUSH START ", 170, 400); - if (pad.st != 1) { goto WAIT_READY; } - } - - set_schedule_assumption(sche_game_opening); - - WAIT_READY: - return; -} - */ - - -void -sche_game_opening(Game *game) -{ - static int blink_count = 0; - if (game->play_id==1){ - if (blink_count < 35) { - gFont_SetString("PUSH START !!", 170, 380); - } - blink_count = (blink_count > 70) ? 0 : blink_count + 1; - - if (pad.st != 1) { goto OPENING; } - } - - - set_schedule_assumption(sche_game_select_car); - - OPENING: - return; - - - if (game->play_id == 1) { - if (title_scene() < 0){ - } - } else if (game->play_id == 2) { - if (i==0){ - title_init_call(); - i=1; - } - } - - -} - -void -sche_game_select_car(Game *game) -{ - if (i==1){ - title_finish_call(); - i=2; - } - gSprite_PutSpriteEx(SP_SEL_CAR+game->car_id, 190, 200, 1.5, 1.5); - gSprite_PutSprite(24, 460, 300); - gSprite_PutSprite(25, 120, 300); - gFont_SetString("SELECT CAR", 180, 50); - - if (pad.right == 1) { - game->car_id = - (game->car_id > MAXCAR-1) ? 1 : game->car_id + 1; - } - if (pad.left == 1) { - game->car_id = - (game->car_id < 2) ? MAXCAR : game->car_id - 1; - } - - if (game->play_id == 1) - if (pad.circle != 1) { goto SELECT_CAR; } - - - set_schedule_assumption(sche_game_select_course); - - SELECT_CAR: - return; -} - -void -sche_game_select_course(Game *game) -{ - gSprite_PutSpriteEx(SP_SEL_COURSE+game->course_id, 190, 200, 1.7, 1.8); - gSprite_PutSprite(24, 460, 300); - gSprite_PutSprite(25, 120, 300); - - gFont_SetString("SELECT COURSE", 150, 50); - - if (game->play_id == 1) { - if (pad.right == 1) { - game->course_id = - (game->course_id > MAXFIELD-1) ? 1 : game->course_id + 1; - goto SELECT_COURSE; - } - if (pad.left == 1) { - game->course_id = - (game->course_id < 2) ? MAXFIELD : game->course_id - 1; - goto SELECT_COURSE; - } - - if (pad.circle != 1) { goto SELECT_COURSE; } - } - - set_schedule_assumption(sche_game_ready); - - SELECT_COURSE: - return; - -} - -void -sche_game_ready(Game *game) -{ - static int blink_count = 0;// - - gSprite_PutSprite(27+game->play_id,265,10); - gSprite_PutSpriteEx(SP_SEL_CAR+game->car_id, 50, 120, 1.5, 1.5); - gSprite_PutSpriteEx(SP_SEL_COURSE+game->course_id, 340, 120, 1.7, 1.8); - - /* 点滅 */ - if (blink_count < 35) { - gFont_SetString("GAME START !!", 170, 380); - } - blink_count = (blink_count > 70) ? 0 : blink_count + 1; - - set_schedule_assumption(sche_game_main_init); - - - if (pad.st == 1) { - set_schedule_assumption(sche_game_main_init); - } - if (pad.cross > 0) { - set_schedule_assumption(sche_game_select_car); - } - -} - -void -sche_game_main_init(Game *game) -{ - if (!game->jiki) - play_init(game); - RUNNIG=0; - - set_schedule_assumption(sche_game_main_ready); -} - -static void -sche_game_main_ready(Game *game) -{ - gFont_SetString("Loading....", 180, 100); - set_schedule_assumption(sche_game_main); -} - -static void -sche_game_main(Game *game) -{ - /** begin: dispaly RAP TIME **/ - if(RUNNIG==0){ - start_time = game_time_get_msec(); - RUNNIG=1; - } - - time_count = game_time_get_msec() - start_time; - game_time_set_raptime(raptime,time_count); - gFont_SetString("TIME",300,20); - gFont_SetString(raptime,400,20); - /** end: dispaly RAP TIME **/ - - // light_init と init_lightの書き間違え? - init_light(&l); - set_light(&l); - - car_id_update(game, game->jiki); - - field_update(game->jiki); - camera_update(game,game->jiki->body->transfer); - carNode_draw(); - - gFont_SetStringInt(game->rap, 50, 100); - - /* スピードメーター */ - gSprite_DefSprite(23, 1, 1,(int)(106.0*(game->jiki->speed/game->jiki->speed_max)), 34); - gSprite_PutSprite(23, 400, 400); - /* km/h */ - gSprite_PutSprite(26, 470, 350); - /* Rap */ - gSprite_PutSprite(27, 80, 100); - - if (game->rap > MAXRAP) { - ranking = 1; - set_schedule_assumption(sche_game_main_goal); - } - - gFont_SetStringInt((int)(100.0*game->jiki->speed), 380, 350); - - - if ((pad.right > 0) && ((game->jiki->speed != 0) || (pad.circle > 0))) { - car_swerve(game->jiki, 1); - } - if ((pad.left > 0) && ((game->jiki->speed != 0) || (pad.circle > 0))) { - car_swerve(game->jiki, -1); - } - if (pad.circle > 0) { - car_accelerate(game->jiki, 1); - } - if (pad.cross > 0) { - car_accelerate(game->jiki, -1); - } - - if (pad.r1 == 1) { - game->camera_type = !game->camera_type; - } - if (pad.st == 1) { - set_schedule_assumption(sche_game_main_pause); - } - -} - - -void -sche_game_main_pause(Game *game) -{ - static int select = 0; - - field_update(game->jiki); - carNode_draw(); - - if (game->play_id == 1) { - // 選択マーク - gSprite_PutSprite(17, 100, 190+select*100); - - gFont_SetString("BACK TO GAME", 200, 200); - gFont_SetString("GO TO TITLE", 200, 300); - } else { - gFont_SetString("Pause ...", 200, 200); - } - - - if (pad.circle == 1) { - if (select == 0) { - set_schedule_assumption(sche_game_main); - } else { - set_schedule_assumption(sche_game_main_finish); - } - } else if (pad.st == 1) { - set_schedule_assumption(sche_game_main); - } else if (pad.up == 1 || pad.down == 1) { - select = !select; - } - -} - - -void -sche_game_main_goal(Game *game) -{ - /** dispaly TOTAL TIME **/ - game_time_set_raptime(raptime,time_count); - - gFont_SetString("TOTAL TIME",150,20); - gFont_SetString(raptime,400,20); - gFont_SetString("GOAL !!", 220, 150); - -#ifdef LINDA - if (ranking == 1) - gFont_SetString("You WIN!!", 200, 250); - else - gFont_SetString("You Lose...", 200, 250); -#endif - - - // 宣言では引数が二つだったから、第一引数に game を入れてみた - car_update(game, game->jiki); - field_update(game->jiki); - carNode_draw(); - camera_update(game,game->jiki->body->transfer); - - if (pad.st == 1) { - set_schedule_assumption(sche_game_main_finish); - } - -} - -void -sche_game_main_finish(Game *game) -{ - field_destroy(); - carNode_destroy(); - game_env_init(game); - - set_schedule_assumption(sche_game_main_finish2); -} - -void -sche_game_main_finish2(Game *game) -{ - gFont_SetString("GAME OVER ...", 200, 200); - - - if (pad.st == 1) { - set_schedule_assumption(sche_game_opening); - } - -} - -// 適当に作りました -void wait_sync(Game *game) -{ - printf("wait_sync\n"); -} - -// 適当に -void swap_dbuff() -{ - printf("swap_dbuff()\n"); -} - -void -schedule(Game *game) -{ - sche_func(game); - - if (linda_update(change_state, game) == true){ - set_schedule(game); - } - else{ - unset_schedule(); - } - - wait_sync(game); - swap_dbuff(); - sjoy_poll(); - - ps2util_sprite_Draw(); - gSprite_Draw_Reset(); - gFont_Draw_Reset(); -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/schedule.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,512 @@ +/* schedule.c */ + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <stdbool.h> +#include "libps2.h" +#include "ps2util.h" +#include "field.h" +#include "car.h" +#include "gSprite.h" +#include "gFont.h" +#include "game.h" +#include "controler.h" +#include "camera.h" +#include "carNode.h" +#include "light.h" +#include "title_scene.h" +#include "game_time.h" +#include "schedule.h" +#include "game.h" + +#include "mytype.h" +#include "linda.h" + +#include "sjoy.h" + +#ifdef LINDA +bool linda_update(int p, Game *game); +#else +#define linda_update(change_state, game) true +#endif + +#define MAXCAR 3 // 選択可能機体 +#define MAXFIELD 2 // 選択可能コース +#define MAXRAP 3 // ラップ数 +#define SP_SEL_CAR 50 +#define SP_SEL_COURSE 80 + +// controler.cより +extern SGO_PAD pad; + + +static void set_schedule(Game *game); +static void sche_game_init(Game *game); +//static void sche_game_wait(Game *game); //プロトタイプも消しといた +//static void sche_game_wait_ready(Game *game); +static void sche_game_opening(Game *game); +static void sche_game_select_car(Game *game); +static void sche_game_select_course(Game *game); +static void sche_game_ready(Game *game); +static void sche_game_main_init(Game *game); +static void sche_game_main_ready(Game *game); +static void sche_game_main(Game *game); +static void sche_game_main_pause(Game *game); +static void sche_game_main_goal(Game *game); +static void sche_game_main_finish(Game *game); +static void sche_game_main_finish2(Game *game); + + + +/* timer */ +static int start_time,time_count; +static int RUNNIG=0; +char raptime[10]; + +static int ranking = 0; +static LIGHT l; +static int i=0; + +static void (*sche_func_assumption)(); +static void (*sche_func)() = &sche_game_init; +static int change_state = 0; + +// schedule.cで使用してる +void linda_env_init( void ); + +static void +set_schedule_assumption(void *_func) +{ + sche_func_assumption = _func; + change_state = 1; +} + +static void +unset_schedule() +{ + change_state = 0; +} + +static void +set_schedule(Game *game) +{ + sche_func = sche_func_assumption; + change_state = 0; +} + +static void +graphic_init() +{ + gSprite_Init(); // グラフィック関連の初期化 + gFont_Init(); // フォント関連の初期化 +} + +static void +play_init( Game *game ) +{ + game->jiki = car_init(game->car_id); + carNode_append(game->jiki); + field_init(game->course_id); +} + +// 適当に自作 :miya +void linda_env_init( void ) +{ + printf("linda_env_init\n"); +} + +static void game_env_init ( Game *game ) +{ + game->car_id = 1; + game->course_id = 1; + game->camera_type = 0; + game->rap = 1; + game->jiki = NULL; + + ranking = 0; + + wait_init(); + linda_env_init(); +} + + + +void +sche_game_init(Game *game) +{ + game_env_init(game); + graphic_init(); + camera_init(); + +#ifdef LINDA + //sche_func = &sche_game_wait; + //set_schedule_assumption(sche_game_wait); +#else + set_schedule_assumption(sche_game_opening); +#endif +} + +/** + * 通信対戦専用 + * 全ユーザが接続するまで待つ + * ・・・だったんだけど、現在 linda を切っているため worning が出る。 + * ので cut する。 + */ + +/* linda を使用しないのでカットした +static void +sche_game_wait(Game *game) +{ + gFont_SetString("WAITING...", 200, 100); + set_schedule_assumption(sche_game_wait_ready); +} +*/ + + +/** + * 通信対戦専用 + * 全ユーザの接続を確認したら呼び出す + * こいつも、linda がないので cut +*/ + /* +static void +sche_game_wait_ready(Game *game) +{ + gFont_SetString("CONNECT OK!!", 170, 300); + if (game->play_id == 1) { + gFont_SetString(" PUSH START ", 170, 400); + if (pad.st != 1) { goto WAIT_READY; } + } + + set_schedule_assumption(sche_game_opening); + + WAIT_READY: + return; +} + */ + + +void +sche_game_opening(Game *game) +{ + static int blink_count = 0; + if (game->play_id==1){ + if (blink_count < 35) { + gFont_SetString("PUSH START !!", 170, 380); + } + blink_count = (blink_count > 70) ? 0 : blink_count + 1; + + if (pad.st != 1) { goto OPENING; } + } + + + set_schedule_assumption(sche_game_select_car); + + OPENING: + return; + + + if (game->play_id == 1) { + if (title_scene() < 0){ + } + } else if (game->play_id == 2) { + if (i==0){ + title_init_call(); + i=1; + } + } + + +} + +void +sche_game_select_car(Game *game) +{ + if (i==1){ + title_finish_call(); + i=2; + } + gSprite_PutSpriteEx(SP_SEL_CAR+game->car_id, 190, 200, 1.5, 1.5); + gSprite_PutSprite(24, 460, 300); + gSprite_PutSprite(25, 120, 300); + gFont_SetString("SELECT CAR", 180, 50); + + if (pad.right == 1) { + game->car_id = + (game->car_id > MAXCAR-1) ? 1 : game->car_id + 1; + } + if (pad.left == 1) { + game->car_id = + (game->car_id < 2) ? MAXCAR : game->car_id - 1; + } + + if (game->play_id == 1) + if (pad.circle != 1) { goto SELECT_CAR; } + + + set_schedule_assumption(sche_game_select_course); + + SELECT_CAR: + return; +} + +void +sche_game_select_course(Game *game) +{ + gSprite_PutSpriteEx(SP_SEL_COURSE+game->course_id, 190, 200, 1.7, 1.8); + gSprite_PutSprite(24, 460, 300); + gSprite_PutSprite(25, 120, 300); + + gFont_SetString("SELECT COURSE", 150, 50); + + if (game->play_id == 1) { + if (pad.right == 1) { + game->course_id = + (game->course_id > MAXFIELD-1) ? 1 : game->course_id + 1; + goto SELECT_COURSE; + } + if (pad.left == 1) { + game->course_id = + (game->course_id < 2) ? MAXFIELD : game->course_id - 1; + goto SELECT_COURSE; + } + + if (pad.circle != 1) { goto SELECT_COURSE; } + } + + set_schedule_assumption(sche_game_ready); + + SELECT_COURSE: + return; + +} + +void +sche_game_ready(Game *game) +{ + static int blink_count = 0;// + + gSprite_PutSprite(27+game->play_id,265,10); + gSprite_PutSpriteEx(SP_SEL_CAR+game->car_id, 50, 120, 1.5, 1.5); + gSprite_PutSpriteEx(SP_SEL_COURSE+game->course_id, 340, 120, 1.7, 1.8); + + /* 点滅 */ + if (blink_count < 35) { + gFont_SetString("GAME START !!", 170, 380); + } + blink_count = (blink_count > 70) ? 0 : blink_count + 1; + + set_schedule_assumption(sche_game_main_init); + + + if (pad.st == 1) { + set_schedule_assumption(sche_game_main_init); + } + if (pad.cross > 0) { + set_schedule_assumption(sche_game_select_car); + } + +} + +void +sche_game_main_init(Game *game) +{ + if (!game->jiki) + play_init(game); + RUNNIG=0; + + set_schedule_assumption(sche_game_main_ready); +} + +static void +sche_game_main_ready(Game *game) +{ + gFont_SetString("Loading....", 180, 100); + set_schedule_assumption(sche_game_main); +} + +static void +sche_game_main(Game *game) +{ + /** begin: dispaly RAP TIME **/ + if(RUNNIG==0){ + start_time = game_time_get_msec(); + RUNNIG=1; + } + + time_count = game_time_get_msec() - start_time; + game_time_set_raptime(raptime,time_count); + gFont_SetString("TIME",300,20); + gFont_SetString(raptime,400,20); + /** end: dispaly RAP TIME **/ + + // light_init と init_lightの書き間違え? + init_light(&l); + set_light(&l); + + car_id_update(game, game->jiki); + + field_update(game->jiki); + camera_update(game,game->jiki->body->transfer); + carNode_draw(); + + gFont_SetStringInt(game->rap, 50, 100); + + /* スピードメーター */ + gSprite_DefSprite(23, 1, 1,(int)(106.0*(game->jiki->speed/game->jiki->speed_max)), 34); + gSprite_PutSprite(23, 400, 400); + /* km/h */ + gSprite_PutSprite(26, 470, 350); + /* Rap */ + gSprite_PutSprite(27, 80, 100); + + if (game->rap > MAXRAP) { + ranking = 1; + set_schedule_assumption(sche_game_main_goal); + } + + gFont_SetStringInt((int)(100.0*game->jiki->speed), 380, 350); + + + if ((pad.right > 0) && ((game->jiki->speed != 0) || (pad.circle > 0))) { + car_swerve(game->jiki, 1); + } + if ((pad.left > 0) && ((game->jiki->speed != 0) || (pad.circle > 0))) { + car_swerve(game->jiki, -1); + } + if (pad.circle > 0) { + car_accelerate(game->jiki, 1); + } + if (pad.cross > 0) { + car_accelerate(game->jiki, -1); + } + + if (pad.r1 == 1) { + game->camera_type = !game->camera_type; + } + if (pad.st == 1) { + set_schedule_assumption(sche_game_main_pause); + } + +} + + +void +sche_game_main_pause(Game *game) +{ + static int select = 0; + + field_update(game->jiki); + carNode_draw(); + + if (game->play_id == 1) { + // 選択マーク + gSprite_PutSprite(17, 100, 190+select*100); + + gFont_SetString("BACK TO GAME", 200, 200); + gFont_SetString("GO TO TITLE", 200, 300); + } else { + gFont_SetString("Pause ...", 200, 200); + } + + + if (pad.circle == 1) { + if (select == 0) { + set_schedule_assumption(sche_game_main); + } else { + set_schedule_assumption(sche_game_main_finish); + } + } else if (pad.st == 1) { + set_schedule_assumption(sche_game_main); + } else if (pad.up == 1 || pad.down == 1) { + select = !select; + } + +} + + +void +sche_game_main_goal(Game *game) +{ + /** dispaly TOTAL TIME **/ + game_time_set_raptime(raptime,time_count); + + gFont_SetString("TOTAL TIME",150,20); + gFont_SetString(raptime,400,20); + gFont_SetString("GOAL !!", 220, 150); + +#ifdef LINDA + if (ranking == 1) + gFont_SetString("You WIN!!", 200, 250); + else + gFont_SetString("You Lose...", 200, 250); +#endif + + + // 宣言では引数が二つだったから、第一引数に game を入れてみた + car_update(game, game->jiki); + field_update(game->jiki); + carNode_draw(); + camera_update(game,game->jiki->body->transfer); + + if (pad.st == 1) { + set_schedule_assumption(sche_game_main_finish); + } + +} + +void +sche_game_main_finish(Game *game) +{ + field_destroy(); + carNode_destroy(); + game_env_init(game); + + set_schedule_assumption(sche_game_main_finish2); +} + +void +sche_game_main_finish2(Game *game) +{ + gFont_SetString("GAME OVER ...", 200, 200); + + + if (pad.st == 1) { + set_schedule_assumption(sche_game_opening); + } + +} + +// 適当に作りました +void wait_sync(Game *game) +{ + printf("wait_sync\n"); +} + +// 適当に +void swap_dbuff() +{ + printf("swap_dbuff()\n"); +} + +void +schedule(Game *game) +{ + sche_func(game); + + if (linda_update(change_state, game) == true){ + set_schedule(game); + } + else{ + unset_schedule(); + } + + wait_sync(game); + swap_dbuff(); + sjoy_poll(); + + ps2util_sprite_Draw(); + gSprite_Draw_Reset(); + gFont_Draw_Reset(); +}
--- a/schedule.h Thu Jun 02 17:26:21 2011 +0900 +++ b/schedule.h Thu Jun 02 17:51:41 2011 +0900 @@ -5,7 +5,7 @@ #endif // game.hからここに移動 -void schedule(); +void schedule(Game *game); // car.hから。 void car_update( Game *game, CarPtr car );
--- a/sjoy.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,144 +0,0 @@ -// Copyright(C) 2001 Sony Computer Entertainment Inc. All Rights Reserved. -// -// "sjoy.c" -// -// -#include <stdio.h> -#include <unistd.h> -#include <fcntl.h> -#include <assert.h> - - -#include "sjoy.h" - -#define N_JOY 2 - -static char *g_devName[N_JOY] = { - "/dev/js0", - "/dev/js1", -}; - -static int g_fd[N_JOY] = { - -1, -1, -}; - -//static __u32 g_button[N_JOY]; // max 32 buttons per joystick -//static __s16 g_axis[N_JOY][2]; // max 2 axis per joystick - -//---------------------------------------------------------------------- -int sjoy_open(void) -{ - int joy; - - sjoy_close(); - - for (joy = 0; joy < N_JOY; joy++) { - assert(g_fd[joy] == -1); - g_fd[joy] = open(g_devName[joy], O_RDONLY | O_NONBLOCK); - if (g_fd[joy] < 0) { - fprintf(stderr, "can't open %s\n", g_devName[joy]); - fprintf(stderr, - "You don't have permission, or should load module for joysticks.\n" - "How to load joystick module:\n" - " # modprobe ps2pad\n"); - return -1; - } - } - - return 0; -} - -//---------------------------------------------------------------------- -int sjoy_close(void) -{ - int joy; - int fail = 0; - - for (joy = 0; joy < N_JOY; joy++) { - if (g_fd[joy] >= 0) { - fail |= close(g_fd[joy]); - } - g_fd[joy] = -1; - } - - return fail ? -1 : 0; -} - -/* 適当に自作:miya */ -struct js_event -{ - int type; - int number; - int value; -}; - -int g_button[10]; -int g_axis[10][10]; - -#define JS_EVENT_INIT 1 -#define JS_EVENT_BUTTON 2 -#define JS_EVENT_AXIS 3 -/* ここまで適当に自作:miya */ - - -//---------------------------------------------------------------------- -void sjoy_poll(void) -{ - int joy; - - for (joy = 0; joy < N_JOY; joy++) { - if (g_fd[joy] < 0) { - continue; - } - for (; ;) { - struct js_event e; - int n = read(g_fd[joy], &e, sizeof(e)); - if (n != sizeof(e)) { - break; - } - switch (e.type & ~JS_EVENT_INIT) { - case JS_EVENT_BUTTON: - g_button[joy] &= ~(1 << e.number); - g_button[joy] |= (e.value << e.number); - break; - - case JS_EVENT_AXIS: - g_axis[joy][e.number] = e.value; - break; - - default: - assert(0); - break; - } - } - } - -} - -//---------------------------------------------------------------------- -int sjoy_get_button(int joy) -{ - return g_button[joy]; -} - -//---------------------------------------------------------------------- -int sjoy_get_axis(int joy, int axis) -{ - return g_axis[joy][axis]; -} - -//---------------------------------------------------------------------- -int sjoy_get_ps2_button(int joy) -{ - int w = g_button[joy]; - int a0 = g_axis[joy][0]; - int a1 = g_axis[joy][1]; - int th = 0x4000; - - w |= (a0 < -th) ? SJOY_PS2_L_LEFT : 0; - w |= (a1 > th) ? SJOY_PS2_L_DOWN : 0; - w |= (a0 > th) ? SJOY_PS2_L_RIGHT : 0; - w |= (a1 < -th) ? SJOY_PS2_L_UP : 0; - - return w; -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sjoy.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,144 @@ +// Copyright(C) 2001 Sony Computer Entertainment Inc. All Rights Reserved. +// +// "sjoy.c" +// +// +#include <stdio.h> +#include <unistd.h> +#include <fcntl.h> +#include <assert.h> + + +#include "sjoy.h" + +#define N_JOY 2 + +static char *g_devName[N_JOY] = { + "/dev/js0", + "/dev/js1", +}; + +static int g_fd[N_JOY] = { + -1, -1, +}; + +//static __u32 g_button[N_JOY]; // max 32 buttons per joystick +//static __s16 g_axis[N_JOY][2]; // max 2 axis per joystick + +//---------------------------------------------------------------------- +int sjoy_open(void) +{ + int joy; + + sjoy_close(); + + for (joy = 0; joy < N_JOY; joy++) { + assert(g_fd[joy] == -1); + g_fd[joy] = open(g_devName[joy], O_RDONLY | O_NONBLOCK); + if (g_fd[joy] < 0) { + fprintf(stderr, "can't open %s\n", g_devName[joy]); + fprintf(stderr, + "You don't have permission, or should load module for joysticks.\n" + "How to load joystick module:\n" + " # modprobe ps2pad\n"); + return -1; + } + } + + return 0; +} + +//---------------------------------------------------------------------- +int sjoy_close(void) +{ + int joy; + int fail = 0; + + for (joy = 0; joy < N_JOY; joy++) { + if (g_fd[joy] >= 0) { + fail |= close(g_fd[joy]); + } + g_fd[joy] = -1; + } + + return fail ? -1 : 0; +} + +/* 適当に自作:miya */ +struct js_event +{ + int type; + int number; + int value; +}; + +int g_button[10]; +int g_axis[10][10]; + +#define JS_EVENT_INIT 1 +#define JS_EVENT_BUTTON 2 +#define JS_EVENT_AXIS 3 +/* ここまで適当に自作:miya */ + + +//---------------------------------------------------------------------- +void sjoy_poll(void) +{ + int joy; + + for (joy = 0; joy < N_JOY; joy++) { + if (g_fd[joy] < 0) { + continue; + } + for (; ;) { + struct js_event e; + int n = read(g_fd[joy], &e, sizeof(e)); + if (n != sizeof(e)) { + break; + } + switch (e.type & ~JS_EVENT_INIT) { + case JS_EVENT_BUTTON: + g_button[joy] &= ~(1 << e.number); + g_button[joy] |= (e.value << e.number); + break; + + case JS_EVENT_AXIS: + g_axis[joy][e.number] = e.value; + break; + + default: + assert(0); + break; + } + } + } + +} + +//---------------------------------------------------------------------- +int sjoy_get_button(int joy) +{ + return g_button[joy]; +} + +//---------------------------------------------------------------------- +int sjoy_get_axis(int joy, int axis) +{ + return g_axis[joy][axis]; +} + +//---------------------------------------------------------------------- +int sjoy_get_ps2_button(int joy) +{ + int w = g_button[joy]; + int a0 = g_axis[joy][0]; + int a1 = g_axis[joy][1]; + int th = 0x4000; + + w |= (a0 < -th) ? SJOY_PS2_L_LEFT : 0; + w |= (a1 > th) ? SJOY_PS2_L_DOWN : 0; + w |= (a0 > th) ? SJOY_PS2_L_RIGHT : 0; + w |= (a1 < -th) ? SJOY_PS2_L_UP : 0; + + return w; +}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test_vector.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,189 @@ +#include <stdio.h> +#include "ps2util.h" +#include "libps2.h" + +void init_FVECTOR(FVECTOR v, float num); +void init_FMATRIX(FMATRIX m, float num); +void output_FVECTOR(FVECTOR v); +void output_FMATRIX(FMATRIX m); +void all_init(FVECTOR v0, FVECTOR v1, FMATRIX m0, FMATRIX m1, float num); + + +/* + ps2util.c にある、vector 計算のテスト用処理です。 +*/ + +int main(){ + + FVECTOR resultV; + FMATRIX resultM; + float resultf; + + FVECTOR v0,v1; + FMATRIX m0,m1; + + float f0 = 0.5; + float num = 0.1; + + int i,j; + int lim1 = 4; + + //v0,v1,m0,m1 を初期化 + all_init(v0, v1, m0, m1, num); + + printf("v0\n"); + output_FVECTOR(v0); + + printf("v1\n"); + output_FVECTOR(v1); + + printf("m0\n"); + output_FMATRIX(m0); + + printf("m1\n"); + output_FMATRIX(m1); + + printf("\n"); + printf("\n"); + + + + + /*-----------ps2util.c test----------*/ + + ps2_vu0_copy_vector(v0, v1); + printf("ps2_vu0_copy_vector(v0, v1)\n"); + output_FVECTOR(v0); + output_FVECTOR(v1); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_unit_matrix(m0); + printf("ps2_vu0_unit_matrix(m0)\n"); + output_FMATRIX(m0); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_rot_matrix_y(resultM, m0, f0); + printf("ps2_vu0_rot_matrix_y(resultM, m0, f0)\n"); + output_FMATRIX(resultM); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_apply_matrix(resultV, m0, v0); + printf("ps2_vu0_apply_matrix(resultV, m0, v0)\n"); + output_FVECTOR(resultV); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_scale_vector(resultV, v0, f0); + printf("ps2_vu0_sacle_vector(resultV, v0, f0)\n"); + output_FVECTOR(resultV); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_add_vector(resultV, v0, v1); + printf("ps2_vu0_add_vector(resultV, v0, v1)\n"); + output_FVECTOR(resultV); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_outer_product(resultV, v0, v1); + printf("ps2_vu0_outer_product(resultV, v0, v1)\n"); + output_FVECTOR(resultV); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + resultf = ps2_vu0_inner_product(v0, v1); + printf("ps2_vu0_inner_product(v0, v1)\n"); + printf("resultf = %10f\n",resultf); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_mul_matrix(resultM, m0, m1); + printf("ps2_vu0_mul_matrix(resultM, m0, m1)\n"); + output_FMATRIX(resultM); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_copy_matrix(m0, m1); + printf("ps2_vu0_copy_matrix(m0, m1)\n"); + output_FMATRIX(m0); + output_FMATRIX(m0); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_sub_vector(resultV, v0, v1); + printf("ps2_vu0_sub_vector(resultV, v0, v1)\n"); + output_FVECTOR(resultV); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + ps2_vu0_normalize(resultV, v0); + printf("ps2_vu0_normalize(result, v0)\n"); + output_FVECTOR(resultV); + printf("\n"); + all_init(v0, v1, m0, m1, num); + + +} + + + +//使用する値の初期化 FVECTOR +void init_FVECTOR(FVECTOR v, float num){ + int i; + int lim1=4; + for ( i=0; i<lim1; i++ ) { + v[i] = num + ( (float)i * num * 0.3 ) ; + } + v[3] = 1; +} + +//使用する値の初期化 FMATRIX +void init_FMATRIX(FMATRIX m, float num){ + int i,j; + int lim1=4; + for ( i=0; i<lim1; i++ ) { + for ( j=0; j<lim1; j++ ) { + m[i][j] = ( num * (float)j ) + ( (float)i * num*4.0 ) ; + } + } + m[0][3] = m[1][3] = m[2][3] = 0; + + m[3][0] = m[3][1] = m[3][2] = 0; + m[3][3] = 1; +} + +//--------出力--------- +void output_FVECTOR(FVECTOR v){ + int i; + int lim1 = 4; + for ( i=0; i<lim1; i++ ) { + printf("%10f ",v[i]); + } + printf("\n\n"); +} + +//--------出力--------- +void output_FMATRIX(FMATRIX m){ + int i,j; + int lim1 = 4; + for ( i=0; i<lim1; i++ ) { + for ( j=0; j<lim1; j++ ) { + printf("%10f",m[i][j]); + } + printf("\n"); + } + printf("\n"); +} + + + +//全部を初期値に戻す。 +void all_init(FVECTOR v0, FVECTOR v1, FMATRIX m0, FMATRIX m1, float num){ + init_FVECTOR(v0, num); + init_FVECTOR(v1, num*2); + init_FMATRIX(m0, num); + init_FMATRIX(m1, num*2); +}
--- a/title_scene.c Thu Jun 02 17:26:21 2011 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,88 +0,0 @@ -#include "libps2.h" -#include "ps2util.h" -#include "title_scene.h" -#include "gSprite.h" - -#include "sjoy.h" - - -typedef enum { - TITLE_INIT, - TITLE_MAIN, - TITLE_FINISH -} TITLE_STATE; - -static ps2utilSprite title_sprite; - -static TEXTURE *title_img; - -#define TITLE_IMG_FILE "img/title.png" - - -static void -title_init() -{ - - //load texture - - title_img = read_png_file( TITLE_IMG_FILE ); - ps2util_tex_Set( title_img ); - - /* - create sprite object - */ - - ps2util_sprite_Create( &title_sprite, title_img ); - ps2util_sprite_Set_basicAttribute( &title_sprite, - 0, 0, 650, 500, 0, 0, 512, 256, SPRITE_PRIO_FOREGROUND ); - - ps2util_sprite_Use_alpha( &title_sprite ); - ps2util_sprite_Request( &title_sprite ); -} - -void -title_init_call() -{ - title_init(); -} - -static void -title_finish() -{ - ps2util_sprite_Destroy( &title_sprite ); - ps2util_tex_Exclude( title_img ); - free_texture( title_img ); -} - -void -title_finish_call() -{ - title_finish(); -} - -int -title_scene() -{ - static TITLE_STATE state = TITLE_INIT; - int pad; - - switch (state) { - case TITLE_INIT: - title_init(); - state = TITLE_MAIN; - break; - - case TITLE_MAIN: - pad = sjoy_get_ps2_button( JOYPAD_1 ); - state = (pad & SJOY_PS2_START) ? TITLE_FINISH : TITLE_MAIN; - break; - - case TITLE_FINISH: - title_finish(); - return -1; - - default: - break; - } - return 0; -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/title_scene.cc Thu Jun 02 17:51:41 2011 +0900 @@ -0,0 +1,88 @@ +#include "libps2.h" +#include "ps2util.h" +#include "title_scene.h" +#include "gSprite.h" + +#include "sjoy.h" + + +typedef enum { + TITLE_INIT, + TITLE_MAIN, + TITLE_FINISH +} TITLE_STATE; + +static ps2utilSprite title_sprite; + +static TEXTURE *title_img; + +#define TITLE_IMG_FILE "img/title.png" + + +static void +title_init() +{ + + //load texture + + title_img = read_png_file( TITLE_IMG_FILE ); + ps2util_tex_Set( title_img ); + + /* + create sprite object + */ + + ps2util_sprite_Create( &title_sprite, title_img ); + ps2util_sprite_Set_basicAttribute( &title_sprite, + 0, 0, 650, 500, 0, 0, 512, 256, SPRITE_PRIO_FOREGROUND ); + + ps2util_sprite_Use_alpha( &title_sprite ); + ps2util_sprite_Request( &title_sprite ); +} + +void +title_init_call() +{ + title_init(); +} + +static void +title_finish() +{ + ps2util_sprite_Destroy( &title_sprite ); + ps2util_tex_Exclude( title_img ); + free_texture( title_img ); +} + +void +title_finish_call() +{ + title_finish(); +} + +int +title_scene() +{ + static TITLE_STATE state = TITLE_INIT; + int pad; + + switch (state) { + case TITLE_INIT: + title_init(); + state = TITLE_MAIN; + break; + + case TITLE_MAIN: + pad = sjoy_get_ps2_button( JOYPAD_1 ); + state = (pad & SJOY_PS2_START) ? TITLE_FINISH : TITLE_MAIN; + break; + + case TITLE_FINISH: + title_finish(); + return -1; + + default: + break; + } + return 0; +}