Mercurial > hg > old > magoroku_racing
view field.c @ 53:a233027e895c
*** empty log message ***
author | gongo |
---|---|
date | Wed, 08 Nov 2006 07:19:26 +0000 |
parents | a1908b83f8fa |
children | ce9ef7dcf2f0 |
line wrap: on
line source
/* * $Id$ */ #include <stdio.h> #include <stdlib.h> #include "libps2.h" #include "ps2util.h" #include "mytype.h" #include "field.h" #include "car.h" #include "quotanion.h" #define DEFAULT_SET (EFFECT_TEXTURE_USE | EFFECT_ALPHABLEND_UNUSE | EFFECT_SHADING_FLAT) #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; 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); //$B$3$3$G%3!<%9$NAv$l$k>l=j(B($BEv$?$jH=Dj(B) 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': // $B%3!<%9(BID$B$NFI$_<h$j(B if (!flag) { sscanf(bufp, " %d\n", &course_id); if (id == course_id) { flag = TRUE; } } else { goto FINISH_LOAD; } break; case 't': // $B%F%/%9%A%c$N%m!<%I(B if (flag) { sscanf(bufp, " %s\n", texname); tex = read_png_file(texname); ps2util_tex_Set(tex); } break; case 'c': // $B%3!<%9$N%m!<%I(B 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: // $B@hF,$H:G8eHx$N%j%s%/$rD%$k(B newField->next = newField->init; newField->init->prev = newField; field_list = field_actual = fieldHead; } /*---------------------/ FieldPtr field_init: $B;XDj$7$?%U%!%$%k$+$i%3!<%9$r@8@.$9$k!#(B $BLa$jCM(B $B%3!<%9@hF,$N%]%$%s%?(B /---------------------*/ 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; } /* * $B<~2s5-O?!#(B1$B<~$9$kKh$K(B1$B$rJV$9!#(B */ 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; }