annotate example/scenegraph/xml/task/collision.cpp @ 350:dd3888980738

add tasts.xml renderer.xml
author admin@mcbk.cr.ie.u-ryukyu.ac.jp
date Fri, 10 Jul 2009 16:41:20 +0900
parents
children 852d7ba57be2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
350
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
1 /**
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
2 * SceneGraph が増えてくると動かなくなるかもしれない。
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
3 * 一応 mainMem とかで動くようになるとは思うけど。
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
4 * だめだったら、そこら辺が怪しいと思うべき
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
5 */
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
6
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
7 // #define DEBUG
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
8 #include "error.h"
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
9
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
10 #include "CreatePolygon.h"
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
11 #include "polygon_pack.h"
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
12 #include "scene_graph_pack.h"
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
13
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
14 SchedDefineTask(CreatePolygon);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
15
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
16 #define SG_PACK_LOAD 10
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
17 #define SG_NODE_LOAD 11
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
18 #define PP_LOAD 12
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
19 #define PP_STORE 13
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
20
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
21 /**
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
22 * あとで直す
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
23 */
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
24 static void
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
25 rotate(float *xyz, float *matrix)
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
26 {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
27 float abc[4];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
28
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
29 abc[0] = xyz[0];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
30 abc[1] = xyz[1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
31 abc[2] = xyz[2];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
32 abc[3] = xyz[3];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
33
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
34 for(int i=0; i<4; i++)
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
35 {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
36 xyz[i] = abc[0]*matrix[i] + abc[1]*matrix[i+4] + abc[2]*matrix[i+8] + abc[3]*matrix[i+12];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
37 }
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
38 }
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
39
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
40 int
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
41 CreatePolygon::run(void *rbuf, void *wbuf)
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
42 {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
43 __debug_spe("CreatePolygon\n");
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
44
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
45 float xyz1[4],xyz2[4],xyz3[4];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
46
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
47 SceneGraphPackPtr sgp = (SceneGraphPack*)smanager->get_input(0);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
48 SceneGraphPackPtr next_sgp =
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
49 (SceneGraphPackPtr)smanager->allocate(sizeof(SceneGraphPack));
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
50 SceneGraphPackPtr free_sgp = next_sgp;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
51 SceneGraphPackPtr tmp_sgp;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
52
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
53 SceneGraphNodePtr node;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
54 SceneGraphNodePtr next_node
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
55 = (SceneGraphNodePtr)smanager->allocate(sizeof(SceneGraphNode));
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
56 SceneGraphNodePtr free_node = next_node;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
57 SceneGraphNodePtr tmp_node;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
58
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
59 PolygonPackPtr pp
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
60 = (PolygonPackPtr)smanager->allocate(sizeof(PolygonPack));
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
61 PolygonPackPtr send_pp
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
62 = (PolygonPackPtr)smanager->allocate(sizeof(PolygonPack));
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
63 PolygonPackPtr pp_addr = (PolygonPackPtr)smanager->get_param(0);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
64 PolygonPackPtr tmp_pp;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
65
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
66 pp->init();
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
67 send_pp->init();
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
68
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
69 do {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
70 if (sgp->next != NULL) {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
71 smanager->dma_load(next_sgp, (uint32)sgp->next,
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
72 sizeof(SceneGraphPack), SG_PACK_LOAD);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
73 } else {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
74 next_sgp = NULL;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
75 }
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
76
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
77 for (int i = 0; i < sgp->info.size; i++) {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
78 node = &sgp->node[i];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
79
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
80 do {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
81 if (node->next != NULL) {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
82 smanager->dma_load(next_node, (uint32)node->next,
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
83 sizeof(SceneGraphNode), SG_NODE_LOAD);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
84 } else {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
85 next_node = NULL;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
86 }
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
87
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
88 for (int n = 0, nt = 0; n < node->size*3; n+=9, nt+=6) {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
89
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
90 if (pp->info.size >= MAX_SIZE_TRIANGLE) {
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
91 PolygonPackPtr next;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
92
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
93 // smanager から Task を作る、0 ではなく PolygonPack->task_id が良い
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
94 smanager->mainMem_alloc(0, sizeof(PolygonPack));
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
95 smanager->mainMem_wait();
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
96 next = (PolygonPackPtr)smanager->mainMem_get(0);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
97
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
98 pp->next = next; // この部分は TaskManager 側でやるべき
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
99
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
100 tmp_pp = pp;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
101 pp = send_pp;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
102 send_pp = tmp_pp;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
103
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
104 smanager->dma_wait(PP_STORE);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
105 smanager->dma_store(send_pp, (uint32)pp_addr,
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
106 sizeof(PolygonPack), PP_STORE);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
107
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
108 pp_addr = next;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
109
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
110 smanager->dma_wait(PP_LOAD); // 多分不要
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
111 smanager->dma_load(pp, (uint32)pp_addr,
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
112 sizeof(PolygonPack), PP_LOAD);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
113 // 次の dma_wait のコストが高いのでパイプラインで隠す必要がある
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
114
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
115 smanager->dma_wait(PP_LOAD);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
116 pp->init();
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
117
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
118 }
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
119
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
120 TrianglePack *triangle = &pp->tri[pp->info.size++];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
121
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
122 xyz1[0] = node->vertex[n];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
123 xyz1[1] = node->vertex[n+1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
124 xyz1[2] = node->vertex[n+2]*-1;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
125 xyz1[3] = 1;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
126 xyz2[0] = node->vertex[n+3];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
127 xyz2[1] = node->vertex[n+3+1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
128 xyz2[2] = node->vertex[n+3+2]*-1;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
129 xyz2[3] = 1;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
130 xyz3[0] = node->vertex[n+6];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
131 xyz3[1] = node->vertex[n+6+1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
132 xyz3[2] = node->vertex[n+6+2]*-1;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
133 xyz3[3] = 1;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
134
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
135 rotate(xyz1, node->translation);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
136 rotate(xyz2, node->translation);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
137 rotate(xyz3, node->translation);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
138
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
139 triangle->ver1.x = xyz1[0];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
140 triangle->ver1.y = xyz1[1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
141 triangle->ver1.z = xyz1[2];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
142 triangle->ver1.tex_x = node->texture[nt];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
143 triangle->ver1.tex_y = node->texture[nt+1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
144
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
145 triangle->ver2.x = xyz2[0];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
146 triangle->ver2.y = xyz2[1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
147 triangle->ver2.z = xyz2[2];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
148 triangle->ver2.tex_x = node->texture[nt+2];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
149 triangle->ver2.tex_y = node->texture[nt+2+1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
150
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
151 triangle->ver3.x = xyz3[0];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
152 triangle->ver3.y = xyz3[1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
153 triangle->ver3.z = xyz3[2];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
154 triangle->ver3.tex_x = node->texture[nt+4];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
155 triangle->ver3.tex_y = node->texture[nt+4+1];
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
156
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
157 #if 1
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
158 triangle->tex_info.addr = node->tex_addr;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
159 triangle->tex_info.width = node->tex_width;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
160 triangle->tex_info.height = node->tex_height;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
161 #else
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
162 triangle->tex_info.addr = node->texture_info.pixels;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
163 triangle->tex_info.width = node->texture_info.t_w;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
164 triangle->tex_info.height = node->texture_info.t_h;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
165 #endif
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
166 }
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
167
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
168 smanager->dma_wait(SG_NODE_LOAD);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
169
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
170 tmp_node = node;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
171 node = next_node;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
172 next_node = tmp_node;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
173 } while (node);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
174
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
175 next_node = free_node;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
176 }
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
177
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
178 smanager->dma_wait(SG_PACK_LOAD);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
179
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
180 tmp_sgp = sgp;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
181 sgp = next_sgp;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
182 next_sgp = tmp_sgp;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
183 } while (sgp);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
184
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
185 smanager->dma_wait(PP_STORE);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
186 smanager->dma_store(pp, (uint32)pp_addr,
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
187 sizeof(PolygonPack), PP_STORE);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
188 smanager->dma_wait(PP_STORE);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
189
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
190 free(pp);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
191 free(send_pp);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
192 free(free_node);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
193 free(free_sgp);
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
194
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
195 return 0;
dd3888980738 add tasts.xml renderer.xml
admin@mcbk.cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
196 }