Mercurial > hg > Game > Cerium
annotate TaskManager/Test/test_render/polygon.cpp @ 138:f35504025f73 draft
オブジェクトを増やして複数の表示に成功。
TODO:オブジェクトの削除
author | gongo@charles.cr.ie.u-ryukyu.ac.jp |
---|---|
date | Fri, 28 Nov 2008 12:16:24 +0900 |
parents | 91c74dbc32e4 |
children | 56db76a03294 |
rev | line source |
---|---|
109 | 1 #include <iostream> |
2 #include <SDL.h> | |
3 #include <SDL_opengl.h> | |
4 #include <SDL_image.h> | |
5 #include "polygon.h" | |
6 #include "xml.h" | |
7 #include "texture.h" | |
8 #include "sys.h" | |
9 #include "triangle.h" | |
10 #include "vertex.h" | |
11 #include "Span.h" | |
12 #include "SpanC.h" | |
13 #include "scene_graph_pack.h" | |
14 #include "error.h" | |
120 | 15 #include "viewer_types.h" |
109 | 16 using namespace std; |
17 | |
18 //extern int decode(char *cont, char *file_name); | |
19 extern int decode(char *cont, FILE *outfile); | |
20 | |
21 | |
22 SDL_Surface* Polygon::texture_image; | |
23 | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
24 Polygon::Polygon(void) |
109 | 25 { |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
26 xyz[0] = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
27 xyz[1] = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
28 xyz[2] = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
29 xyz[3] = 1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
30 c_xyz[0] = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
31 c_xyz[1] = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
32 c_xyz[2] = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
33 c_xyz[3] = 1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
34 angle[0] = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
35 angle[1] = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
36 angle[2] = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
37 angle[3] = 1; |
109 | 38 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
39 for (int i = 0; i < 16; i++) { |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
40 matrix[i] = 0; |
109 | 41 } |
42 } | |
43 | |
138 | 44 void |
45 Polygon::position_init(void) | |
46 { | |
47 xyz[0] = 0; | |
48 xyz[1] = 0; | |
49 xyz[2] = 0; | |
50 xyz[3] = 1; | |
51 c_xyz[0] = 0; | |
52 c_xyz[1] = 0; | |
53 c_xyz[2] = 0; | |
54 c_xyz[3] = 1; | |
55 angle[0] = 0; | |
56 angle[1] = 0; | |
57 angle[2] = 0; | |
58 angle[3] = 1; | |
59 | |
60 for (int i = 0; i < 16; i++) { | |
61 matrix[i] = 0; | |
62 } | |
63 } | |
64 | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
65 #if 0 |
109 | 66 void Polygon::draw(SceneGraphPack *sgp) |
67 { | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
68 float xyz1[4],xyz2[4],xyz3[4]; |
109 | 69 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
70 /***SceneGraphUpdate***/ |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
71 //sgp_update(); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
72 for (int i = 0; i < sgp->info.size; i++) { |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
73 SceneGraphNode node = sgp->node[i]; |
109 | 74 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
75 /***draw***/ |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
76 int n,nt; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
77 for(n=0,nt=0; n<node.size*3; n+=9,nt+=6) { |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
78 xyz1[0] = node.vertex[n]; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
79 xyz1[1] = node.vertex[n+1]; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
80 xyz1[2] = node.vertex[n+2]*-1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
81 xyz1[3] = 1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
82 xyz2[0] = node.vertex[n+3]; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
83 xyz2[1] = node.vertex[n+3+1]; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
84 xyz2[2] = node.vertex[n+3+2]*-1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
85 xyz2[3] = 1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
86 xyz3[0] = node.vertex[n+6]; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
87 xyz3[1] = node.vertex[n+6+1]; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
88 xyz3[2] = node.vertex[n+6+2]*-1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
89 xyz3[3] = 1; |
109 | 90 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
91 rotate(xyz1, node.translation); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
92 rotate(xyz2, node.translation); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
93 rotate(xyz3, node.translation); |
109 | 94 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
95 Vertex *ver1 = new Vertex(xyz1[0],xyz1[1],xyz1[2],node.texture[nt],node.texture[nt+1]); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
96 Vertex *ver2 = new Vertex(xyz2[0],xyz2[1],xyz2[2],node.texture[nt+2],node.texture[nt+2+1]); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
97 Vertex *ver3 = new Vertex(xyz3[0],xyz3[1],xyz3[2],node.texture[nt+4],node.texture[nt+4+1]); |
109 | 98 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
99 Triangle *tri = new Triangle(ver1,ver2,ver3); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
100 Span_c *span = new Span_c(); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
101 span->viewer = viewer; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
102 span->p = this; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
103 span->create_span(tri,texture_image); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
104 delete ver1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
105 delete ver2; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
106 delete ver3; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
107 delete tri; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
108 delete span; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
109 } |
109 | 110 } |
111 } | |
112 | |
113 | |
114 void Polygon::draw(PolygonPack *pp) | |
115 { | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
116 for(int n=0; n<pp->info.size; n++) |
109 | 117 { |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
118 Vertex *ver1 = new Vertex(pp->tri[n].ver1.x,pp->tri[n].ver1.y,pp->tri[n].ver1.z,pp->tri[n].ver1.tex_x,pp->tri[n].ver1.tex_y); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
119 Vertex *ver2 = new Vertex(pp->tri[n].ver2.x,pp->tri[n].ver2.y,pp->tri[n].ver2.z,pp->tri[n].ver2.tex_x,pp->tri[n].ver2.tex_y); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
120 Vertex *ver3 = new Vertex(pp->tri[n].ver3.x,pp->tri[n].ver3.y,pp->tri[n].ver3.z,pp->tri[n].ver3.tex_x,pp->tri[n].ver3.tex_y); |
109 | 121 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
122 Triangle *tri = new Triangle(ver1,ver2,ver3); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
123 Span_c *span = new Span_c(); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
124 span->viewer = viewer; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
125 span->p = this; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
126 span->create_span(tri,texture_image); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
127 delete ver1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
128 delete ver2; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
129 delete ver3; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
130 delete tri; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
131 delete span; |
109 | 132 } |
133 } | |
134 | |
135 void Polygon::draw(SpanPack *sp) | |
136 { | |
137 Span *span; | |
138 | |
139 for (int n = 0; n < sp->info.size; n++) { | |
140 span = &sp->span[n]; | |
141 | |
123
e9e12e2088bd
delete scene_graph->child (instead use "children")
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
120
diff
changeset
|
142 //int x = span->x; |
e9e12e2088bd
delete scene_graph->child (instead use "children")
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
120
diff
changeset
|
143 //int y = span->y; |
109 | 144 float z = span->start_z; |
145 int end = span->length_x; | |
146 float zpos = span->end_z; | |
147 float tex1 = span->tex_x1; | |
148 float tex2 = span->tex_x2; | |
149 float tey1 = span->tex_y1; | |
150 float tey2 = span->tex_y2; | |
151 Uint32 rgb; | |
152 int tex_xpos; | |
153 int tex_ypos; | |
154 int tex_zpos; | |
155 float tex_x, tex_y, tex_z; | |
156 | |
157 if (end == 1) { | |
158 tex_xpos = (int)((span->tex_height-1) * tex1); | |
159 tex_ypos = (int)((span->tex_width-1) * tey1); | |
160 tex_zpos = (int)z; | |
161 rgb = get_rgb(tex_xpos, tex_ypos); | |
162 //viewer->write_pixel(x, y, zpos, rgb); | |
163 } else { | |
164 for (int j = 0; j < end; j++) { | |
165 tex_x = tex1*(end-1-j)/(end-1) + tex2*j/(end-1); | |
166 tex_y = tey1*(end-1-j)/(end-1) + tey2*j/(end-1); | |
167 tex_z = z*(end-1-j)/(end-1) + zpos*j/(end-1); | |
168 if (tex_x > 1) tex_x = 1; | |
169 if (tex_y > 1) tex_y = 1; | |
170 tex_xpos = (int)((span->tex_height-1) * tex_x); | |
171 tex_ypos = (int)((span->tex_width-1) * tex_y); | |
172 rgb = get_rgb(tex_xpos,tex_ypos); | |
173 //viewer->write_pixel(j + x, y, tex_z, rgb); | |
174 } | |
175 } | |
176 } | |
177 } | |
178 | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
179 #endif |
109 | 180 |
181 void Polygon::pickup_coordinate(char *cont) | |
182 { | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
183 for(int n=0; n<size*3; n+=3) |
109 | 184 { |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
185 cont = pickup_float(cont, data+n); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
186 cont = pickup_float(cont, data+n+1); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
187 cont = pickup_float(cont, data+n+2); |
109 | 188 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
189 if (cont == NULL) |
109 | 190 { |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
191 cout << "Analyzing obj data failed coordinate\n"; |
109 | 192 } |
193 } | |
194 } | |
195 | |
196 void Polygon::pickup_normal(char *cont) | |
197 { | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
198 for(int n=size*3;n<size*6;n+=3) |
109 | 199 { |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
200 cont = pickup_float(cont,data+n); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
201 cont = pickup_float(cont,data+n+1); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
202 cont = pickup_float(cont,data+n+2); |
109 | 203 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
204 if (cont == NULL) |
109 | 205 { |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
206 cout << "Analyzing obj data failed normal\n"; |
109 | 207 } |
208 } | |
209 } | |
210 | |
211 void Polygon::pickup_model(char *cont) | |
212 { | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
213 cont = pickup_float(cont,c_xyz); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
214 cont = pickup_float(cont,c_xyz+1); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
215 cont = pickup_float(cont,c_xyz+2); |
109 | 216 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
217 if (cont == NULL) |
109 | 218 { |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
219 cout << "Analyzing obj data failed model\n"; |
109 | 220 } |
221 } | |
222 | |
223 void Polygon::pickup_texture(char *cont) | |
224 { | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
225 for(int n=size*6; n<size*9; n+=3) |
109 | 226 { |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
227 cont = pickup_float(cont,data+n); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
228 cont = pickup_float(cont,data+n+1); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
229 data[n+2] = 1.0; |
109 | 230 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
231 if (cont == NULL) |
109 | 232 { |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
233 cout << "Analyzing obj data failed texture\n"; |
109 | 234 } |
235 } | |
236 } | |
237 | |
238 char *get_pixel(int tx, int ty, SDL_Surface *texture_image) | |
239 { | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
240 return (char*)texture_image->pixels+(texture_image->format->BytesPerPixel*((texture_image->w)*ty+tx)); |
109 | 241 } |
242 | |
243 unsigned my_ntohl(unsigned u) { | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
244 // rr gg bb 00 |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
245 // rr |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
246 // bb gg rr |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
247 //unsigned u1 = ((u&0xff)<<24) + |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
248 // ((u&0xff00)<<8) + |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
249 // ((u&0xff0000)>>8) + |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
250 // ((u&0xff000000)>>24); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
251 unsigned u1; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
252 unsigned b = (u&0xff000000)>>24; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
253 unsigned g = (u&0xff0000)>>16; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
254 unsigned r = (u&0xff00)>>8; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
255 u1 = r + (g<<8) + (b<<16); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
256 //printf("pixel %x->%x\n",u,u1); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
257 return u1; |
109 | 258 } |
259 | |
260 Uint32 Polygon::get_rgb(int tx, int ty) | |
261 { | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
262 SDL_PixelFormat *fmt; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
263 //Uint32 temp, pixel; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
264 Uint8 red, green, blue; |
109 | 265 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
266 fmt = texture_image->format; |
109 | 267 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
268 if (tx<0) tx = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
269 if (texture_image->w-1< tx) tx = texture_image->w-1 ; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
270 if (ty<0) ty = 0; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
271 if (texture_image->h-1< ty) ty = texture_image->h-1 ; |
109 | 272 |
273 | |
274 | |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
275 //SDL_LockSurface(texture_image); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
276 char *p = get_pixel(tx,ty,texture_image); |
109 | 277 #if 0 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
278 pixel = my_ntohl(*(Uint32*)p); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
279 //printf("pixel = %d\n", pixel); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
280 //printf("pixel %x bpp = %d ",p, fmt->BytesPerPixel); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
281 //SDL_UnlockSurface(texture_image); |
109 | 282 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
283 temp = pixel&fmt->Rmask; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
284 temp = temp>>fmt->Rshift; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
285 temp = temp<<fmt->Rloss; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
286 red = (Uint8)temp; |
109 | 287 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
288 temp = pixel&fmt->Gmask; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
289 temp = temp>>fmt->Gshift; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
290 temp = temp<<fmt->Gloss; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
291 green = (Uint8)temp; |
109 | 292 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
293 temp = pixel&fmt->Bmask; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
294 temp = temp>>fmt->Bshift; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
295 temp = temp<<fmt->Bloss; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
296 blue = (Uint8)temp; |
109 | 297 #endif |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
298 blue = (Uint8) p[0]; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
299 green = (Uint8) p[1]; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
300 red = (Uint8) p[2]; |
109 | 301 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
302 //printf("tx = %d ty = %d ", tx,ty); |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
303 //printf("pixel color => R: %d, G: %d, B: %d\n", red, green, blue); |
123
e9e12e2088bd
delete scene_graph->child (instead use "children")
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
120
diff
changeset
|
304 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
305 SDL_PixelFormat *pf; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
306 //pf = viewer->screen->format; |
109 | 307 |
137
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
308 //cout << SDL_MapRGB(pf, red, green, blue) << endl; |
91c74dbc32e4
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
130
diff
changeset
|
309 return SDL_MapRGB(pf, red, green, blue); |
109 | 310 } |