annotate field.cc @ 122:5219bf3d5e71

title_draw
author e085768
date Mon, 27 Jun 2011 19:44:46 +0900
parents b6dc70f6aa7e
children 6ef3b0efdeaf
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
1 #include <stdio.h>
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
2 #include <stdlib.h>
90
8edae89a3877 compile on Mac OS X
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 88
diff changeset
3 #include <stdbool.h>
91
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
4 #include <string.h>
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
5 #include "libps2.h"
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
6 #include "ps2util.h"
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
7 #include "mytype.h"
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
8 #include "field.h"
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
9 #include "car.h"
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
10 #include "quotanion.h"
90
8edae89a3877 compile on Mac OS X
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 88
diff changeset
11 #include <stdbool.h>
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
12
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
13 #define BUFSIZE 256
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
14
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
15 /* --- main.c --- */
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
16 extern FILE *main_fp;
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
17
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
18 static int field_num_max = 0;
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
19 static int field_num = 1;
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
20
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
21 static FieldPtr field_list;
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
22 static FieldPtr field_actual;
91
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
23
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
24 // 適当に自作:miya
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
25 PolygonInfo xml_read_file(char *colImg)
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
26 {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
27 PolygonInfo test;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
28 printf("xml_read_file");
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
29
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
30 return test;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
31 }
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
32
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
33 /*
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
34 static FieldPtr
115
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
35 field_create(char *fieldImg, char *colImg, OBJECT *tex)
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
36 {
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
37 FieldPtr self;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
38 OBJECT *obj;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
39 PolygonInfo *xml;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
40 void *free_addr;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
41
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
42 FVECTOR location = {0, 0, 0, 1};
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
43 FVECTOR direction = {0, 0, 0, 1};
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
44
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
45 obj = ps2util_obj_Create_fromXML(fieldImg);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
46 memcpy(obj->xyz, location, sizeof(FVECTOR));
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
47 memcpy(obj->angle, direction, sizeof(FVECTOR));
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
48 ps2util_obj_Renew_transMatrix(obj);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
49 ps2util_obj_Set_effect(obj, DEFAULT_SET);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
50 ps2util_obj_Set_texture(obj, tex);
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
51
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
52 // xml = xml_read_file(colImg); //ここでコースの走れる場所(当たり判定)
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
53
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
54 if (malloc_align16(&free_addr, &self, sizeof(Field)) == -1) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
55 fprintf(stderr, "field.c: malloc_align16 error\n");
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
56 fflush(stderr);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
57 exit(EXIT_FAILURE);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
58 }
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
59 self->object = obj;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
60 self->next = NULL;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
61 self->prev = NULL;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
62 self->free_addr = free_addr;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
63 #ifdef DEBUG
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
64 fprintf(main_fp, "malloc fieldNode addr = %x(free), %x(obj)\n", (int)free_addr, (int)self);
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
65 #endif
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
66 col_init(&self->colface, xml);
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
67
34
55f2d0326c4d *** empty log message ***
gongo
parents: 33
diff changeset
68 #ifdef DEBUG
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
69 fprintf(main_fp, " facenum = %d\n", self->colface.facenum);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
70 fprintf(main_fp, " facenum = %x(free), ", (int)self->colface.free_addr);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
71 fprintf(main_fp, "facenum = %x(obj)\n", (int)self->colface.colface);
34
55f2d0326c4d *** empty log message ***
gongo
parents: 33
diff changeset
72 #endif
55f2d0326c4d *** empty log message ***
gongo
parents: 33
diff changeset
73
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
74 //xml_free(xml);
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
75
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
76 return self;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
77 }
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
78 */
91
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
79
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
80
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
81 static void
32
b5c5ffd4d2f2 *** empty log message ***
gongo
parents: 18
diff changeset
82 field_new_readCSV(FILE *fp, int id)
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
83 {
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
84 FieldPtr fieldHead = NULL;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
85 FieldPtr newField = NULL;
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
86 //FieldPtr prevField = NULL;
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
87 char buff[BUFSIZE], *bufp;
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
88 //char fieldImg[BUFSIZE], colImg[BUFSIZE], texname[BUFSIZE];
115
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
89
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
90 //TEXTURE *tex = NULL;
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
91 int course_id;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
92 bool flag = false;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
93
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
94 while ((bufp = fgets(buff, BUFSIZE, fp)) != NULL) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
95 bufp++;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
96
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
97 switch (buff[0]) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
98 case 'n': // コースIDの読み取り
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
99 if (!flag) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
100 sscanf(bufp, " %d\n", &course_id);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
101 if (id == course_id) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
102 flag = true;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
103 }
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
104 } else {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
105 goto FINISH_LOAD;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
106 }
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
107 break;
115
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
108
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
109 /*
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
110 case 't': // テクスチャのロード
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
111 if (flag) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
112 sscanf(bufp, " %s\n", texname);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
113 //tex = read_png_file(texname);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
114 ps2util_tex_Set(tex);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
115 }
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
116 break;
115
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
117 */
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
118
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
119 /*
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
120 case 'c': // コースのロード
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
121 if (flag) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
122 sscanf(bufp, " %s %s\n", fieldImg, colImg);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
123 newField = field_create(fieldImg, colImg, tex);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
124 if (!fieldHead) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
125 fieldHead = prevField = newField;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
126 } else {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
127 prevField->next = newField;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
128 newField->prev = prevField;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
129 prevField = newField;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
130 }
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
131 newField->init = fieldHead;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
132 field_num_max++;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
133 }
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
134 break;
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
135 */
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
136 default:
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
137 break;
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
138
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
139 }
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
140
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
141 }
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
142
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
143 FINISH_LOAD:
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
144 // 先頭と最後尾のリンクを張る
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
145 newField->next = newField->init;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
146 newField->init->prev = newField;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
147
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
148 field_list = field_actual = fieldHead;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
149 }
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
150
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
151
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
152 /*---------------------/
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
153 FieldPtr
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
154 field_init:
88
ce9ef7dcf2f0 convert UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
155 指定したファイルからコースを生成する。
ce9ef7dcf2f0 convert UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
156 戻り値
ce9ef7dcf2f0 convert UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
157 コース先頭のポインタ
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
158 /---------------------*/
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
159 void
32
b5c5ffd4d2f2 *** empty log message ***
gongo
parents: 18
diff changeset
160 field_init(int id)
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
161 {
115
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
162 FILE *fp;
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
163 const char *filename = "course/course.dat";
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
164
115
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
165 if (!(fp = fopen(filename, "r"))) {
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
166 fprintf(main_fp, "error read file %s\n", filename);
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
167 exit(EXIT_FAILURE);
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
168 }
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
169 field_new_readCSV(fp, id);
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
170 fclose(fp);
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
171 }
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
172
118
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
173 void test(FMATRIX m, FVECTOR l )
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
174 {
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
175 ps2_vu0_unit_matrix(m);
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
176
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
177 for( int i = 0; i < 4; i ++ )
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
178 m[3][i] = l[i];
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
179 }
91
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
180
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
181 static void
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
182 field_draw(FieldPtr p)
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
183 {
118
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
184 // p->object->matrix を 二次元配列で扱う関数?
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
185 // 下の5行っぽいことしたい
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
186 test( (FMATRIX)p->object->matrix, p->location );
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
187
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
188 //ps2_vu0_unit_matrix((FMATRIX)(p->object->matrix));
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
189
118
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
190 //p->object->matrix[3][0] = p->location[0];
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
191 //p->object->matrix[3][1] = p->location[1];
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
192 //p->object->matrix[3][2] = p->location[2];
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
193 //p->object->matrix[3][3] = p->location[3];
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
194
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
195 // 上の5この処理、このやり方でも出来そう?
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
196 /*
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
197 for( int i = 0; i < 4; i ++ )
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
198 p->object->matrix[12+i] = p->location[0];
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
199 */
b6dc70f6aa7e chenge OBJECT->transfer
e085768
parents: 116
diff changeset
200
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
201 ps2util_obj_Draw(p->object);
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
202 }
91
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
203
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
204
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
205 void field_update(CarPtr car)
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
206 {
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
207 FieldPtr p;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
208
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
209 p = field_actual;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
210 // current
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
211 p->location[0] = -car->location[0];
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
212 p->location[1] = -car->location[1];
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
213 p->location[2] = -car->location[2];
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
214 p->location[3] = 1;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
215 field_draw(p);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
216
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
217 // next
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
218 p = field_actual->next;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
219 if (p) {
91
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
220 p->location[0] = -car->location[0];
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
221 p->location[1] = -car->location[1];
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
222 p->location[2] = -car->location[2];
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
223 p->location[3] = 1;
cb6c6de125dc halfway
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 90
diff changeset
224 field_draw(p);
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
225 }
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
226
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
227 // prev
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
228 p = field_actual->prev;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
229 if (p) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
230 p->location[0] = -car->location[0];
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
231 p->location[1] = -car->location[1];
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
232 p->location[2] = -car->location[2];
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
233 p->location[3] = 1;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
234 field_draw(p);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
235 }
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
236 }
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
237
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
238 void
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
239 field_destroy()
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
240 {
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
241 /*
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
242 FieldPtr p = field_list;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
243 FieldPtr d;
115
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
244
116
ed702e49cc6c conpile
e085768
parents: 115
diff changeset
245
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
246 TEXTURE *t;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
247
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
248 p->prev->next = NULL;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
249
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
250 t = p->object->surfaces->texture;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
251 ps2util_tex_Exclude(t);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
252 free_texture(t);
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
253
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
254 while (p) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
255 d = p;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
256 p = p->next;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
257 ps2util_obj_Free(d->object);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
258 free(d->colface.free_addr);
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
259 free(d->free_addr);
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
260 #ifdef DEBUG
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
261 fprintf(main_fp, "free fieldNode addr = %x\n", (int)d->free_addr);
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
262 #endif
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
263 }
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
264
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
265 field_num_max = 0;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
266 field_num = 1;
115
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
267
31dd5c07f7c1 class OBJECT:SceanGraph
e085768
parents: 100
diff changeset
268 */
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
269 }
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
270
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
271 /*
88
ce9ef7dcf2f0 convert UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
272 * 周回記録。1周する毎に1を返す。
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
273 */
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
274 int
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
275 field_rap_increment(int n)
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
276 {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
277 field_num += n;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
278 if (field_num > field_num_max) {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
279 field_num = 1;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
280 return 1;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
281 } else {
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
282 return 0;
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
283 }
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
284 }
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
285
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
286 void
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
287 field_set_actual(FieldPtr p)
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
288 {
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
289 field_actual = p;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
290 }
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
291
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
292 FieldPtr
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
293 field_get_actual()
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
294 {
96
0b65ca27f113 compile on Mac OS X 2
Atuto SHIROMA <e095729@ie.u-ryukyu.ac.jp>
parents: 91
diff changeset
295 return field_actual;
0
0fae5658fb0b Initial revision
gongo
parents:
diff changeset
296 }