Mercurial > hg > Members > kono > Cerium
annotate TaskManager/Test/test_render/spe/CreateSpan.cpp @ 164:38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
author | gongo@gendarme.cr.ie.u-ryukyu.ac.jp |
---|---|
date | Tue, 09 Dec 2008 10:48:49 +0900 |
parents | 1f4c3f3238e6 |
children | cd1c289f952d |
rev | line source |
---|---|
109 | 1 #include "CreateSpan.h" |
2 #include "viewer_types.h" | |
3 | |
164
38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
4 static const int SPAN_PACK_LOAD = 5; |
38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
5 static const int SPAN_PACK_STORE = 6; |
38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
6 static const int POLYGON_PACK_LOAD = 7; |
38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
7 static const int TILE_ALLOCATE = 8; |
38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
8 static const int TILE_LOAD = 9; |
38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
9 static const int TILE_STORE = 10; |
109 | 10 |
11 static SpanPackPtr spack = NULL; | |
12 static SpanPackPtr send_spack = NULL; | |
13 static int prev_index = 0; | |
14 | |
15 SchedDefineTask(CreateSpan); | |
16 | |
17 static float | |
18 calc(float f1, float f2,int i, float base) | |
19 { | |
20 float ans; | |
21 ans = f1/f2*i + base; | |
22 return ans; | |
23 } | |
24 | |
25 | |
26 /** | |
27 * TrianglePack から、vMin, vMid, vMax を求める | |
28 * | |
29 * @param [triPack] TrianglePack | |
30 * @param [vMin] [vMid] [vMax] | |
31 */ | |
32 static void | |
33 make_vertex(TrianglePack *triPack, | |
34 VertexPackPtr *vMin, VertexPackPtr *vMid, VertexPackPtr *vMax) | |
35 { | |
36 if (triPack->ver1.y <= triPack->ver2.y) { | |
37 if (triPack->ver2.y <= triPack->ver3.y) { | |
38 *vMin = &triPack->ver1; | |
39 *vMid = &triPack->ver2; | |
40 *vMax = &triPack->ver3; | |
41 } else if (triPack->ver3.y <= triPack->ver1.y) { | |
42 *vMin = &triPack->ver3; | |
43 *vMid = &triPack->ver1; | |
44 *vMax = &triPack->ver2; | |
45 } else { | |
46 *vMin = &triPack->ver1; | |
47 *vMid = &triPack->ver3; | |
48 *vMax = &triPack->ver2; | |
49 } | |
50 } else { | |
51 if (triPack->ver1.y <= triPack->ver3.y) { | |
52 *vMin = &triPack->ver2; | |
53 *vMid = &triPack->ver1; | |
54 *vMax = &triPack->ver3; | |
55 } else if (triPack->ver3.y <= triPack->ver2.y) { | |
56 *vMin = &triPack->ver3; | |
57 *vMid = &triPack->ver2; | |
58 *vMax = &triPack->ver1; | |
59 } else { | |
60 *vMin = &triPack->ver2; | |
61 *vMid = &triPack->ver3; | |
62 *vMax = &triPack->ver1; | |
63 } | |
64 } | |
65 } | |
66 | |
67 static void | |
68 make_vMid10(VertexPack *v, VertexPack *vMin, | |
69 VertexPack *vMid, VertexPack *vMax) | |
70 { | |
146 | 71 //int d, d1; |
72 float d; | |
73 int d1; | |
74 | |
75 d = vMax->y - vMin->y; | |
109 | 76 d1 = (int)(vMid->y - vMin->y); |
77 | |
78 v->tex_x = calc(vMax->tex_x - vMin->tex_x, d, d1, vMin->tex_x); | |
79 v->tex_y = calc(vMax->tex_y - vMin->tex_y, d, d1, vMin->tex_y); | |
80 v->x = calc(vMax->x - vMin->x, d, d1, vMin->x); | |
81 v->y = vMid->y; | |
82 v->z = calc(vMax->z - vMin->z, d, d1, vMin->z); | |
83 } | |
84 | |
156 | 85 /** |
161
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
86 * テクスチャは、TEXTURE_SPLIT_PIXEL^2 のブロックに分割する |
156 | 87 * |
161
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
88 * +---+---+---+---+---+---+ |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
89 * | 0 | 1 | 2 | 3 | 4 | 5 | |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
90 * +---+---+---+---+---+---+ |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
91 * | | | | | |11 | |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
92 * +---+---+---+---+---+---+ |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
93 * | | | | | |17 | |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
94 * +---+---+---+---+---+---+ |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
95 * | | | | | |23 | |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
96 * +---+---+---+---+---+---+ |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
97 * | | | | | |29 | |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
98 * +---+---+---+---+---+---+ |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
99 * | | | | | |35 | |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
100 * +---+---+---+---+---+---+ |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
101 * |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
102 * 一辺を TEXTURE_SPLIT とする |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
103 * 各ブロックの数字がブロックIDとなる。 |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
104 */ |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
105 |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
106 /** |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
107 * テクスチャの座標から、 |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
108 * テクスチャのどのブロックかを求める |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
109 * |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
110 * @param[in] tx X coordinates of texture |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
111 * @param[in] tx Y coordinates of texture |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
112 * @param[in] twidth Width of texture |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
113 * @return block ID |
156 | 114 */ |
115 static int | |
161
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
116 get_tex_block(int tx, int ty, int twidth) |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
117 { |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
118 int blockX, blockY; |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
119 |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
120 blockX = tx / TEXTURE_SPLIT_PIXEL; |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
121 blockY = ty / TEXTURE_SPLIT_PIXEL; |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
122 |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
123 return blockX + (twidth/TEXTURE_SPLIT_PIXEL)*blockY; |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
124 } |
1f4c3f3238e6
texture の座標がマイナスになったあと、それを 0 にし忘れてた
gongo@localhost.localdomain
parents:
156
diff
changeset
|
125 |
141 | 126 /** |
133
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
127 * x軸に水平な辺を持つ三角形ポリゴンから、 |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
128 * Span を抜き出す |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
129 */ |
109 | 130 void |
131 CreateSpan::half_triangle(SpanPackPtr *spackList, | |
132 int charge_y_top, int charge_y_end, | |
164
38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
133 uint32 *tex_addr, int tex_width, int tex_height, |
109 | 134 VertexPack *vMin,VertexPack *vMid,VertexPack *vMid10) |
135 { | |
136 float tmp_z,tmp_tex1, tmp_tex2 ,tmp_tey1,tmp_tey2; | |
137 float tmp_xpos,tmp_end,tmp_zpos; | |
138 float start_z, end_z; | |
139 float start_tex_x, end_tex_x, start_tex_y, end_tex_y; | |
140 int x, y, length; | |
141 | |
137
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
142 #if 1 |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
143 // これじゃないと |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
144 // テクスチャの貼りに微妙に隙間が。謎だ |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
145 int start_y = (int)vMid->y; |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
146 int end_y = (int)vMin->y; |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
147 #else |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
148 float start_y = vMid->y; |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
149 float end_y = vMin->y; |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
150 #endif |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
151 float div_y = start_y - end_y; |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
152 int k = 0; |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
153 int l = 1; |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
154 |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
155 SpanPackPtr tmp_spack; |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
156 |
135 | 157 /** |
158 * 三角形ポリゴンをx軸に水平に二つに分けようとして | |
159 * ある一辺がすでに水平だった場合、つまり | |
160 * (環境によっては、back slash が 円マークかも) | |
161 * | |
162 * |\ | |
163 * | \ | |
164 * | \ | |
165 * ----- | |
166 * | |
167 * | |
168 * 上のようなポリゴンだった場合は、本来なら上の部分の三角形にだけ | |
169 * half_triangle の処理をするべきだが、現在の処理だと | |
170 * この half_triangle に「上の部分の三角形」と、 | |
171 * 「『下の部分の三角形と判断してしまった』直線」が来てしまう。 | |
172 * 直線の部分が来ると、calc() で 0 除算とかで、値不定で暴走するので | |
173 * 現在はこれで代用。 | |
174 * half_triangle 呼ぶ前にこれを判断できれば良いかもしれない。 | |
175 * てかこんなんでいいのかよ。。。 | |
176 * | |
177 */ | |
137
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
178 #if 1 |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
179 if ((int)div_y == 0) { |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
180 return; |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
181 } |
6cf991f28c6c
SceneGraphPack の代わりに、今は SceneGraph をそのまま使う様に設定。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
135
diff
changeset
|
182 #else |
135 | 183 if (vMid10->x == vMin->x && vMid10->y == vMin->y) { |
184 return; | |
185 } | |
186 #endif | |
109 | 187 |
188 if (div_y < 0) { | |
189 div_y = -div_y; | |
190 k = 1; | |
191 l = -1; | |
192 } | |
193 | |
135 | 194 for (int i = k; i < (int)div_y+1; i++) { |
109 | 195 y = (int)vMin->y + i*l; |
196 | |
197 /** | |
198 * 担当 y 範囲内 | |
199 */ | |
200 if (charge_y_top <= y && y <= charge_y_end) { | |
201 // 1..8 を index0, 9..16 を index1 にするために y を -1 | |
202 int index = (y-1) / split_screen_h; | |
164
38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
203 |
109 | 204 /** |
205 * 違う SpanPack を扱う場合、 | |
206 * 現在の SpanPack をメインメモリに送り、 | |
207 * 新しい SpanPack を取ってくる | |
208 */ | |
209 if (index != prev_index) { | |
210 tmp_spack = spack; | |
211 spack = send_spack; | |
212 send_spack = tmp_spack; | |
213 | |
214 smanager->dma_wait(SPAN_PACK_STORE); | |
215 smanager->dma_store(send_spack, (uint32)spackList[prev_index], | |
216 sizeof(SpanPack), SPAN_PACK_STORE); | |
217 | |
218 smanager->dma_load(spack, (uint32)spackList[index], | |
219 sizeof(SpanPack), SPAN_PACK_LOAD); | |
220 prev_index = index; | |
221 smanager->dma_wait(SPAN_PACK_LOAD); | |
222 } | |
223 | |
224 /** | |
225 * 書き込む SpanPack が満杯だったら | |
226 * メインメモリで allocate した領域 (next) を持ってきて | |
227 * 現在の spack->next につなぎ、next を次の spack とする。 | |
228 */ | |
229 if (spack->info.size >= MAX_SIZE_SPAN) { | |
230 SpanPackPtr next; | |
231 | |
141 | 232 smanager->mainMem_alloc(0, sizeof(SpanPack)); |
233 smanager->mainMem_wait(); | |
234 next = (SpanPackPtr)smanager->mainMem_get(0); | |
109 | 235 |
236 spack->next = next; | |
237 | |
238 tmp_spack = spack; | |
239 spack = send_spack; | |
240 send_spack = tmp_spack; | |
241 | |
242 smanager->dma_wait(SPAN_PACK_STORE); | |
243 smanager->dma_store(send_spack, (uint32)spackList[index], | |
244 sizeof(SpanPack), SPAN_PACK_STORE); | |
245 | |
246 spackList[index] = next; | |
141 | 247 |
109 | 248 smanager->dma_load(spack, (uint32)spackList[index], |
249 sizeof(SpanPack), SPAN_PACK_LOAD); | |
250 smanager->dma_wait(SPAN_PACK_LOAD); | |
251 spack->init((index+1)*split_screen_h); | |
252 } | |
253 } else { | |
254 /** | |
255 * 担当範囲外だったら無視 | |
256 */ | |
257 continue; | |
258 } | |
146 | 259 |
260 tmp_xpos = calc(vMid10->x - vMin->x ,div_y, i, vMin->x); | |
261 tmp_end = calc(vMid->x - vMin->x ,div_y, i, vMin->x); | |
262 tmp_z = calc(vMid10->z - vMin->z ,div_y, i, vMin->z); | |
263 tmp_zpos = calc(vMid->z - vMin->z ,div_y, i, vMin->z); | |
264 | |
265 length = (tmp_xpos > tmp_end) | |
266 ? (int)tmp_xpos - (int)tmp_end : (int)tmp_end - (int)tmp_xpos; | |
267 if (length == 0) { | |
268 continue; | |
269 } | |
109 | 270 |
271 tmp_tex1 =((i/(div_y)) * vMid10->tex_x) + | |
272 ( ((div_y - i)/(div_y)) * vMin->tex_x); | |
273 tmp_tex2 =( (i/(div_y)) * vMid->tex_x) + | |
274 ( ((div_y - i)/(div_y)) * vMin->tex_x); | |
275 | |
276 tmp_tey1 =( (i/(div_y)) * vMid10->tex_y) + | |
277 ( ((div_y - i)/(div_y)) * vMin->tex_y); | |
278 tmp_tey2 =( (i/(div_y)) * vMid->tex_y) + | |
279 ( ((div_y - i)/(div_y)) * vMin->tex_y); | |
280 | |
281 if (tmp_xpos > tmp_end) { | |
282 x = (int)tmp_end; | |
133
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
283 /** |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
284 * +1 は要らない気がする・・・ |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
285 */ |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
286 //length = (int)(tmp_xpos)-(int)(tmp_end)+1; |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
287 length = (int)(tmp_xpos)-(int)(tmp_end); |
109 | 288 start_z = tmp_zpos; |
289 end_z = tmp_z; | |
290 start_tex_x = tmp_tex2; | |
291 end_tex_x = tmp_tex1; | |
292 start_tex_y = tmp_tey2; | |
293 end_tex_y = tmp_tey1; | |
294 } else { | |
295 x = (int)tmp_xpos; | |
133
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
296 //length = (int)(tmp_end)-(int)(tmp_xpos)+1; |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
297 length = (int)(tmp_end)-(int)(tmp_xpos); |
109 | 298 start_z = tmp_z; |
299 end_z = tmp_zpos; | |
300 start_tex_x = tmp_tex1; | |
301 end_tex_x = tmp_tex2; | |
302 start_tex_y = tmp_tey1; | |
303 end_tex_y = tmp_tey2; | |
304 } | |
305 | |
306 smanager->dma_wait(SPAN_PACK_LOAD); | |
307 | |
308 Span *span = &spack->span[spack->info.size++]; | |
309 | |
310 span->tex_addr = tex_addr; | |
311 span->tex_width = tex_width; | |
312 span->tex_height = tex_height; | |
313 span->x = x; | |
314 span->y = y; | |
315 span->length_x = length; | |
316 span->start_z = start_z; | |
317 span->end_z = end_z; | |
318 span->tex_x1 = start_tex_x; | |
319 span->tex_x2 = end_tex_x; | |
320 span->tex_y1 = start_tex_y; | |
321 span->tex_y2 = end_tex_y; | |
322 } | |
323 } | |
324 | |
325 | |
326 int | |
327 CreateSpan::run(void *rbuf, void *wbuf) | |
328 { | |
329 PolygonPack *pp = (PolygonPack*)smanager->get_input(0); | |
330 PolygonPack *next_pp = | |
331 (PolygonPack*)smanager->allocate(sizeof(PolygonPack)); | |
332 PolygonPack *free_pp = next_pp; | |
333 PolygonPack *tmp_pp; | |
334 | |
335 TrianglePackPtr triPack; | |
336 VertexPackPtr vMin, vMid, vMax; | |
337 VertexPackPtr vMid10 | |
338 = (VertexPackPtr)smanager->allocate(sizeof(VertexPack)); | |
339 | |
340 SpanPackPtr *spackList = (SpanPackPtr*)smanager->get_input(1); | |
341 spack = (SpanPackPtr)smanager->get_input(2); | |
342 send_spack = (SpanPackPtr)smanager->allocate(sizeof(SpanPack)); | |
343 prev_index = get_param(0); | |
344 | |
345 // spack と send_spack は swap しながら DMA を繰り返すので | |
346 // 自分で allocate した send_spack を覚えてないといけない | |
347 SpanPackPtr free_spack = send_spack; | |
348 | |
349 int charge_y_top = get_param(1); | |
350 int charge_y_end = get_param(2); | |
351 | |
352 do { | |
353 if (pp->next != NULL) { | |
354 smanager->dma_load(next_pp, (uint32)pp->next, | |
355 sizeof(PolygonPack), POLYGON_PACK_LOAD); | |
356 } else { | |
357 next_pp = NULL; | |
358 } | |
359 | |
360 for (int i = 0; i < pp->info.size; i++) { | |
361 triPack = &pp->tri[i]; | |
362 | |
363 #if 0 | |
364 make_vertex(triPack, &vMin, &vMid, &vMax); | |
365 #else | |
366 if (triPack->ver1.y <= triPack->ver2.y) { | |
367 if (triPack->ver2.y <= triPack->ver3.y) { | |
368 vMin = &triPack->ver1; | |
369 vMid = &triPack->ver2; | |
370 vMax = &triPack->ver3; | |
371 } else if (triPack->ver3.y <= triPack->ver1.y) { | |
372 vMin = &triPack->ver3; | |
373 vMid = &triPack->ver1; | |
374 vMax = &triPack->ver2; | |
375 } else { | |
376 vMin = &triPack->ver1; | |
377 vMid = &triPack->ver3; | |
378 vMax = &triPack->ver2; | |
379 } | |
380 } else { | |
381 if (triPack->ver1.y <= triPack->ver3.y) { | |
382 vMin = &triPack->ver2; | |
383 vMid = &triPack->ver1; | |
384 vMax = &triPack->ver3; | |
385 } else if (triPack->ver3.y <= triPack->ver2.y) { | |
386 vMin = &triPack->ver3; | |
387 vMid = &triPack->ver2; | |
388 vMax = &triPack->ver1; | |
389 } else { | |
390 vMin = &triPack->ver2; | |
391 vMid = &triPack->ver3; | |
392 vMax = &triPack->ver1; | |
393 } | |
394 } | |
395 #endif | |
396 make_vMid10(vMid10, vMin, vMid, vMax); | |
133
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
397 |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
398 /** |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
399 * ポリゴンを、x軸に水平に分割して二つの三角形を作り、 |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
400 * それぞれから Span を求める |
435e0d24db39
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
113
diff
changeset
|
401 */ |
109 | 402 half_triangle(spackList, charge_y_top, charge_y_end, |
403 triPack->tex_addr, triPack->tex_width, | |
404 triPack->tex_height, vMin, vMid, vMid10); | |
405 half_triangle(spackList, charge_y_top, charge_y_end, | |
406 pp->tri[0].tex_addr, pp->tri[0].tex_width, | |
407 pp->tri[0].tex_height, vMax, vMid, vMid10); | |
408 } | |
409 | |
410 smanager->dma_wait(POLYGON_PACK_LOAD); | |
411 | |
412 tmp_pp = pp; | |
413 pp = next_pp; | |
414 next_pp = tmp_pp; | |
415 } while (pp); | |
416 | |
417 smanager->dma_wait(SPAN_PACK_STORE); | |
418 smanager->dma_store(spack, (uint32)spackList[prev_index], | |
419 sizeof(SpanPack), SPAN_PACK_STORE); | |
420 smanager->dma_wait(SPAN_PACK_STORE); | |
421 | |
422 free(free_pp); | |
423 free(free_spack); | |
424 free(vMid10); | |
425 | |
426 return 0; | |
427 } |