annotate Renderer/test_render/SceneGraph.cpp @ 283:55ea4465b1a2

fix test_render
author e065746@localhost.localdomain
date Fri, 05 Jun 2009 16:49:12 +0900 (2009-06-05)
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
283
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
1 #include <iostream>
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
2 #include <SDL.h>
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
3 #include <SDL_opengl.h>
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
4 #include <SDL_image.h>
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
5 #include <libxml/parser.h>
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
6 #include "SceneGraph.h"
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
7 #include "xml.h"
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
8 #include "sys.h"
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
9 #include "TextureHash.h"
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
10 #include "texture.h"
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
11 #include "TaskManager.h"
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
12
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
13 using namespace std;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
14
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
15 SceneGraphPtr scene_graph = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
16 SceneGraphPtr scene_graph_viewer = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
17
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
18 static TextureHash texture_hash;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
19 struct texture_list list[TABLE_SIZE];
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
20
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
21 // TextureHash.cpp
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
22 extern int id_count;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
23
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
24 extern int decode(char *cont, FILE *outfile);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
25
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
26 static void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
27 no_move(SceneGraphPtr self, int screen_w, int screen_h) {}
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
28
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
29 static void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
30 no_collision(SceneGraphPtr self, int screen_w, int screen_h,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
31 SceneGraphPtr tree) {}
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
32
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
33 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
34 * 事前に計算したテクスチャの最大縮小率 scale まで、
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
35 * テクスチャを 1/2 縮小していく。
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
36 * このとき、テクスチャは TEXTURE_SPLIT_PIXELx2 のブロック (Tile) で分割し、
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
37 * これらを連続したメモリ領域に格納していく。
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
38 * 以下の (1), (2), (3) を Tapestry と呼ぶ
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
39 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
40 * 例 scale = 4 の場合
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
41 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
42 * Tapestry(1) 1/1
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
43 * +---+---+---+---+
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
44 * | 0 | 1 | 2 | 3 |
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
45 * +---+---+---+---+
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
46 * | 4 | 5 | 6 | 7 | (2) 1/2
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
47 * +---+---+---+---+ +---+---+
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
48 * | 8 | 9 | 10| 11| | 16| 17| (3) 1/4
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
49 * +---+---+---+---+ +---+---+ +---+
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
50 * | 12| 13| 14| 15| | 18| 19| | 20|
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
51 * +---+---+---+---+ +---+---+ +---|
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
52 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
53 * (1) (2) (3)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
54 * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
55 * | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | * | * | * | 14| 15| 16| 17| 18| 19| 20|
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
56 * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
57 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
58 * @param[in] tex_w Width of orignal texture
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
59 * @param[in] tex_h Height of orignal texture
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
60 * @param[in] tex_src Original texture
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
61 * @param[in] all_pixel_num Tapestry の合計 pixel 数
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
62 * @param[in] scale テクスチャの最大縮小率 (= 2^n)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
63 * @return (1) のアドレス
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
64 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
65 static uint32*
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
66 makeTapestry(int tex_w, int tex_h, uint32 *tex_src,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
67 int all_pixel_num, int scale_cnt)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
68 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
69 uint32 *tex_dest;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
70
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
71 int t = 0;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
72 int diff = TEXTURE_SPLIT_PIXEL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
73 int p_diff = 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
74
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
75 tex_dest = (uint32*)manager->allocate(sizeof(int)*all_pixel_num);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
76
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
77 while (scale_cnt) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
78 for (int y = 0; y < tex_h; y += diff) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
79 for (int x = 0; x < tex_w; x += diff) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
80 for (int j = 0; j < diff; j += p_diff) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
81 for (int i = 0; i < diff; i += p_diff) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
82 tex_dest[t++]
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
83 = tex_src[(x+i) + tex_w*(y+j)];
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
84 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
85 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
86 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
87 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
88
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
89 diff <<= 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
90 p_diff <<= 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
91 scale_cnt >>= 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
92 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
93
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
94 return tex_dest;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
95 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
96
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
97
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
98 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
99 * 何の情報も持ってない SceneGraph の生成
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
100 * 今のところ、とりあえず木構造の繋がりに使うぐらい
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
101 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
102 SceneGraph::SceneGraph(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
103 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
104 init();
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
105 finalize = &SceneGraph::finalize_copy;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
106
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
107 this->name = "NULLPO";
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
108 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
109
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
110 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
111 * orig のコピーとして SceneGraph を生成する
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
112 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
113 SceneGraph::SceneGraph(SceneGraphPtr orig)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
114 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
115 init();
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
116 memcpy(this, orig, sizeof(SceneGraph));
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
117
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
118 // コピーしない
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
119 //flag_remove = 0;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
120 //flag_drawable = 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
121 next = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
122 prev = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
123 last = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
124
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
125 parent = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
126 brother = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
127 children = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
128 lastChild = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
129
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
130 finalize = &SceneGraph::finalize_copy;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
131
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
132
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
133 frame = 0;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
134 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
135
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
136
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
137 /* construct polygon from xmlNode. */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
138 SceneGraph::SceneGraph(xmlNodePtr surface)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
139 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
140 init();
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
141
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
142 size = atoi((char *)xmlGetProp(surface,(xmlChar *)"size"));
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
143 name = (char *)xmlGetProp(surface,(xmlChar *)"name");
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
144 parent_name = (char *)xmlGetProp(surface,(xmlChar *)"parent");
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
145
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
146 //data = new float[size*3*3];
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
147 coord_xyz = (float*)manager->allocate(sizeof(float)*size*3);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
148 coord_tex = (float*)manager->allocate(sizeof(float)*size*3);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
149 normal = (float*)manager->allocate(sizeof(float)*size*3);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
150
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
151 get_data(surface->children);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
152
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
153 finalize = &SceneGraph::finalize_original;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
154 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
155
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
156 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
157 SceneGraph::init(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
158 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
159 next = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
160 prev = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
161 last = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
162
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
163 parent = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
164 brother = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
165 children = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
166 lastChild = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
167
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
168 stack_xyz[0] = 0.0f;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
169 stack_xyz[2] = 0.0f;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
170 stack_xyz[1] = 0.0f;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
171 stack_angle[0] = 0.0f;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
172 stack_angle[1] = 0.0f;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
173 stack_angle[2] = 0.0f;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
174
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
175 size = 0;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
176 //data = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
177 coord_xyz = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
178 normal = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
179 coord_tex = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
180
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
181 texture_id = -1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
182 move = no_move;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
183 collision = no_collision;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
184
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
185 flag_remove = 0;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
186 flag_drawable = 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
187 sgid = -1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
188
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
189 frame = 0;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
190 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
191
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
192 SceneGraph::~SceneGraph(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
193 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
194 (this->*finalize)();
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
195 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
196
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
197 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
198 * xml ファイルから生成されたオリジナル SceneGraph なので
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
199 * polygon data を削除
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
200 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
201 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
202 SceneGraph::finalize_original(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
203 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
204 //delete [] data;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
205 free(coord_xyz);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
206 free(coord_tex);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
207 free(normal);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
208 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
209
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
210 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
211 * SceneGraph ID から生成された、コピー SceneGraph なので
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
212 * polygon data は削除しない。オリジナルの方で削除する。
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
213 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
214 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
215 SceneGraph::finalize_copy(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
216 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
217 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
218
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
219 /* XMLファイルからポリゴンを作成 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
220 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
221 SceneGraph::createFromXMLfile(const char *xmlfile)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
222 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
223 xmlDocPtr doc;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
224 xmlNodePtr cur;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
225 SceneGraphPtr root = NULL, tmp = NULL, parent;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
226
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
227 /* パース DOM生成 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
228 doc = xmlParseFile(xmlfile);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
229 cur = xmlDocGetRootElement(doc);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
230
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
231 /* ?? */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
232 xmlStrcmp(cur->name,(xmlChar*)"OBJECT-3D");
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
233
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
234 /* XMLのノードを一つずつ解析 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
235 for (cur=cur->children; cur; cur=cur->next) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
236 /* 扱うのはsurfaceオンリー */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
237 //if (xmlStrcmp(cur->name,(xmlChar*)"surface") != 0) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
238 // continue;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
239 //}
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
240 if (!xmlStrcmp(cur->name,(xmlChar*)"surface")) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
241 /* ポリゴン(SceneGraph)生成 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
242 tmp = new SceneGraph(cur);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
243 if ( tmp->parent_name==NULL || 0==strcmp(tmp->parent_name, "NULL")) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
244 /* このsurfaceがroot */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
245 root = tmp;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
246 scene_graph = tmp;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
247 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
248 /* 親はこのsurfaceより前に定義されているものとする (していい?) */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
249 // ここで parent_name を用いるのは間違っていて、
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
250 // *cur->properties->children から探すべきらしい kono
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
251 parent = root->searchSceneGraph(tmp->parent_name);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
252 if (parent==NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
253 fprintf(stderr, "[%s] No such parent %s\n",
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
254 tmp->name, tmp->parent_name);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
255 root->addChild(tmp);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
256 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
257 parent->addChild(tmp);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
258 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
259
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
260 scene_graph->add_next(tmp);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
261 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
262 }else if (!xmlStrcmp(cur->name,(xmlChar*)"image")) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
263
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
264 char *cont;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
265 char image_name[20] = "/tmp/image_XXXXXX";
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
266 char *filename = (char *)xmlGetProp(cur, (xmlChar *)"name");
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
267 int fd = mkstemp(image_name);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
268 FILE *outfile = fdopen(fd, "wb");
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
269 if(NULL == outfile)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
270 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
271 cout << "error open file\n";
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
272 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
273 cont = (char *)xmlNodeGetContent(cur);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
274 decode(cont, outfile);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
275 fclose(outfile);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
276
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
277 int tex_id = texture_hash.hash_regist(filename);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
278 if (tex_id < 0)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
279 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
280
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
281 texture_image = IMG_Load(image_name);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
282
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
283 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
284 * image を 32bit(RGBA) に変換する
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
285 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
286
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
287 SDL_Surface *tmpImage
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
288 = SDL_CreateRGBSurface(SDL_HWSURFACE, texture_image->w,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
289 texture_image->h, 32, redMask,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
290 greenMask, blueMask, alphaMask);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
291 SDL_Surface *converted;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
292 converted = SDL_ConvertSurface(texture_image, tmpImage->format,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
293 SDL_HWSURFACE);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
294 if (converted != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
295 SDL_FreeSurface(texture_image);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
296 texture_image = converted;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
297 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
298
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
299 uint32 *tapestry;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
300 int scale = 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
301 int tex_w = texture_image->w;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
302 int tex_h = texture_image->h;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
303 int all_pixel_num = 0;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
304
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
305 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
306 * テクスチャの w or h が 8 pixel で分割できる間、
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
307 * 1/2 の縮小画像を作る。
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
308 * ここでは、最大の scale (1/scale) を見つける
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
309 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
310 * (ex)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
311 * (128,128) => 64,64 : 32,32: 16,16 : 8,8
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
312 * scale = 16
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
313 * (128, 64) => 64,32 : 32,16: 16,8
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
314 * scale = 8
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
315 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
316
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
317 while (tex_w % TEXTURE_SPLIT_PIXEL == 0 &&
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
318 tex_h % TEXTURE_SPLIT_PIXEL == 0) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
319 all_pixel_num += tex_w*tex_h;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
320 tex_w >>= 1; /* tex_w /= 2 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
321
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
322 tex_h >>= 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
323 scale <<= 1; /* scale *= 2 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
324
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
325 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
326
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
327 scale >>= 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
328
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
329 tapestry = makeTapestry(texture_image->w, texture_image->h,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
330 (uint32*)texture_image->pixels,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
331 all_pixel_num,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
332 scale);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
333
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
334 list[id_count-1].t_w = texture_image->w;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
335 list[id_count-1].t_h = texture_image->h;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
336 list[id_count-1].pixels_orig = (Uint32*)texture_image->pixels;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
337 list[id_count-1].pixels = tapestry;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
338 list[id_count-1].scale_max = scale;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
339
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
340 tmp->texture_id = id_count-1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
341 tmp->texture_info.t_w = texture_image->w;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
342 tmp->texture_info.t_h = texture_image->h;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
343 tmp->texture_info.pixels_orig = (Uint32*)texture_image->pixels;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
344 tmp->texture_info.pixels = tapestry;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
345 tmp->texture_info.scale_max = scale;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
346
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
347 if (unlink(image_name))
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
348 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
349 cout << "unlink error\n";
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
350 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
351
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
352 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
353 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
354 * 以前に Load されている Texture を共用
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
355 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
356
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
357 tmp->texture_id = tex_id;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
358
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
359 // こんなことすると list[] のいみあるのかなーと
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
360 // 微妙に思う、自分で書き換えた感想 by gongo
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
361
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
362 tmp->texture_info.t_w = list[tex_id].t_w;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
363 tmp->texture_info.t_h = list[tex_id].t_h;;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
364 tmp->texture_info.pixels_orig = list[tex_id].pixels_orig;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
365 tmp->texture_info.pixels = list[tex_id].pixels;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
366 tmp->texture_info.scale_max = list[tex_id].scale_max;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
367
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
368 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
369 }else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
370 continue;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
371 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
372 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
373
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
374 xmlFreeDoc(doc);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
375
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
376 //return root;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
377 scene_graph_viewer = root;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
378 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
379
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
380
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
381 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
382 * add Children
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
383 * 親の登録と、brother のリストへ加える
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
384 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
385 * @param child new child
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
386 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
387 SceneGraphPtr
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
388 SceneGraph::addChild(SceneGraphPtr child)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
389 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
390 /* childrenのリストの最後に加える (brother として)*/
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
391 if (this->lastChild != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
392 SceneGraphPtr last = this->lastChild;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
393 last->brother = child;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
394 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
395
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
396 this->lastChild = child;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
397
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
398 if (this->children == NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
399 this->children = child;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
400 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
401
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
402 child->parent = this;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
403
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
404 return child;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
405 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
406
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
407
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
408 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
409 * add Brother
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
410 * addChild() でも brother の操作をしないといけないので、そっちに回す
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
411 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
412 * @param bro new Brother
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
413 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
414 SceneGraphPtr
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
415 SceneGraph::addBrother(SceneGraphPtr bro)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
416 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
417 if (this->parent) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
418 parent->addChild(bro);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
419 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
420 fprintf(stderr, "error : SceneGraph::%s : %s doesn't have parent\n",
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
421 __FUNCTION__, this->name);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
422 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
423
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
424 return bro;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
425 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
426
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
427 /* thisの子や子孫にnameのものが存在すればそいつを返す なければNULL. */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
428 SceneGraphPtr
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
429 SceneGraph::searchSceneGraph(const char *name)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
430 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
431 SceneGraphPtr tmp;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
432 SceneGraphPtr result;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
433
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
434 /* 本人か */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
435 if( 0==strcmp(this->name, name) ) return this;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
436
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
437 /* 子供から再帰的に探す */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
438 for(tmp = this->children; tmp; tmp = tmp->next) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
439 if ((result=tmp->searchSceneGraph(name)) != NULL)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
440 return result;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
441 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
442
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
443 /* 無かったら NULL. */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
444 return NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
445 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
446
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
447 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
448 SceneGraph::tree_check(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
449 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
450 SceneGraphPtr t = this;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
451
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
452 while(t)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
453 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
454 cout << "my_name : " << t->name << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
455 if(t->children != NULL)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
456 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
457 cout << "--move children : " << t->children->name << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
458 t = t->children;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
459 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
460 else if(t->brother != NULL)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
461 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
462 cout << "--move brother : " << t->brother->name << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
463 t = t->brother;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
464 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
465 else
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
466 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
467 while(t)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
468 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
469 if(t->brother != NULL)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
470 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
471 cout << "--move brother : " << t->brother->name << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
472 t = t->brother;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
473 break;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
474 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
475 else
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
476 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
477 if(t->parent)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
478 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
479 cout << "--move parent : " << t->parent->name << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
480 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
481 t = t->parent;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
482 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
483 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
484 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
485 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
486 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
487
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
488
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
489 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
490 SceneGraph::print_member(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
491 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
492 cout << "size = " << size << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
493 cout << "name = " << name << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
494 cout << "parent_name = " << parent_name << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
495
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
496 if (parent != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
497 cout << "parent->name = " << parent->name << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
498 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
499
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
500 if (children != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
501 cout << "children->name = " << children->name << endl;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
502 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
503 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
504
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
505
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
506 /*
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
507 * surface nodeからポリゴンの情報を読み出す 再帰しない
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
508 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
509 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
510 SceneGraph::get_data(xmlNodePtr cur)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
511 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
512 char *cont;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
513 //char *image_name;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
514
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
515 for(;cur;cur=cur->next)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
516 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
517 if(!xmlStrcmp(cur->name,(xmlChar*)"coordinate"))
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
518 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
519 cont = (char *)xmlNodeGetContent(cur);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
520 pickup_coordinate(cont);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
521 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
522 else if(!xmlStrcmp(cur->name,(xmlChar*)"normal"))
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
523 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
524 cont = (char *)xmlNodeGetContent(cur);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
525 pickup_normal(cont);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
526 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
527 else if(!xmlStrcmp(cur->name,(xmlChar*)"model"))
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
528 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
529 cont = (char *)xmlNodeGetContent(cur);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
530 pickup_model(cont);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
531 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
532 else if(!xmlStrcmp(cur->name,(xmlChar*)"texture"))
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
533 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
534 cont = (char *)xmlNodeGetContent(cur);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
535 pickup_texture(cont);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
536 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
537 else if(!xmlStrcmp(cur->name,(xmlChar*)"imageflag"))
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
538 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
539 char *filename = (char *)xmlGetProp(cur, (xmlChar *)"name");
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
540 texture_hash.hash_regist(filename);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
541 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
542 else if(!xmlStrcmp(cur->name,(xmlChar*)"image"))
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
543 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
544 char image_name[20] = "/tmp/image_XXXXXX";
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
545 char *filename = (char *)xmlGetProp(cur, (xmlChar *)"name");
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
546 int fd = mkstemp(image_name);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
547 FILE *outfile = fdopen(fd, "wb");
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
548 if(NULL == outfile)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
549 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
550 cout << "error open file\n";
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
551 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
552 cont = (char *)xmlNodeGetContent(cur);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
553 //decode(cont, image_name);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
554 decode(cont, outfile);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
555 fclose(outfile);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
556
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
557 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
558 * image_name を既に Load していれば何もしない
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
559 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
560 int tex_id = texture_hash.hash_regist(filename);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
561 if (tex_id < 0) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
562
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
563 texture_image = IMG_Load(image_name);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
564
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
565 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
566 * image を 32bit(RGBA) に変換する
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
567 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
568 SDL_Surface *tmpImage
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
569 = SDL_CreateRGBSurface(SDL_HWSURFACE, texture_image->w,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
570 texture_image->h, 32, redMask,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
571 greenMask, blueMask, alphaMask);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
572 SDL_Surface *converted;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
573 converted = SDL_ConvertSurface(texture_image, tmpImage->format,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
574 SDL_HWSURFACE);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
575 if (converted != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
576 SDL_FreeSurface(texture_image);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
577 texture_image = converted;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
578 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
579
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
580 uint32 *tapestry;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
581 int scale = 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
582 int tex_w = texture_image->w;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
583 int tex_h = texture_image->h;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
584 int all_pixel_num = 0;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
585
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
586 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
587 * テクスチャの w or h が 8 pixel で分割できる間、
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
588 * 1/2 の縮小画像を作る。
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
589 * ここでは、最大の scale (1/scale) を見つける
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
590 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
591 * (ex)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
592 * (128,128) => 64,64 : 32,32: 16,16 : 8,8
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
593 * scale = 16
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
594 * (128, 64) => 64,32 : 32,16: 16,8
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
595 * scale = 8
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
596 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
597 while (tex_w % TEXTURE_SPLIT_PIXEL == 0 &&
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
598 tex_h % TEXTURE_SPLIT_PIXEL == 0) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
599 all_pixel_num += tex_w*tex_h;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
600 tex_w >>= 1; /* tex_w /= 2 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
601 tex_h >>= 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
602 scale <<= 1; /* scale *= 2 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
603 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
604
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
605 scale >>= 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
606
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
607 tapestry = makeTapestry(texture_image->w, texture_image->h,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
608 (uint32*)texture_image->pixels,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
609 all_pixel_num, scale);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
610
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
611 list[id_count-1].t_w = texture_image->w;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
612 list[id_count-1].t_h = texture_image->h;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
613 list[id_count-1].pixels_orig = (Uint32*)texture_image->pixels;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
614 list[id_count-1].pixels = tapestry;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
615 list[id_count-1].scale_max = scale;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
616
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
617 texture_id = id_count-1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
618
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
619 if (unlink(image_name))
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
620 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
621 cout << "unlink error\n";
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
622 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
623 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
624 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
625 * 以前に Load されている Texture を共用
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
626 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
627 texture_id = tex_id;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
628 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
629
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
630 // こんなことすると list[] のいみあるのかなーと
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
631 // 微妙に思う、自分で書き換えた感想 by gongo
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
632 texture_info.t_w = list[texture_id].t_w;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
633 texture_info.t_h = list[texture_id].t_h;;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
634 texture_info.pixels_orig = list[texture_id].pixels_orig;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
635 texture_info.pixels = list[texture_id].pixels;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
636 texture_info.scale_max = list[texture_id].scale_max;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
637 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
638 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
639 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
640
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
641
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
642 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
643 SceneGraph::delete_data(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
644 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
645 SceneGraphPtr n = this->next, m;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
646
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
647 //n = this;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
648 //delete [] n->data;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
649
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
650 if (next) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
651 while (n) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
652 m = n->next;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
653 delete n;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
654 n = m;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
655 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
656 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
657 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
658
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
659 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
660 SceneGraph::move_execute(int w, int h)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
661 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
662 (*move)(this, w, h);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
663 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
664
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
665 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
666 SceneGraph::collision_check(int w, int h, SceneGraphPtr tree)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
667 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
668 (*collision)(this, w, h, tree);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
669 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
670
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
671 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
672 SceneGraph::all_execute(int screen_w, int screen_h)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
673 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
674 SceneGraphPtr top = this;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
675 SceneGraphPtr t = top;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
676
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
677 while (t) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
678 t->move_execute(screen_w, screen_h);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
679 t->collision_check(screen_w, screen_h, top);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
680
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
681 t->frame++;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
682
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
683 if (t->parent != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
684 get_matrix(t->matrix, t->angle, t->xyz, t->parent->matrix);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
685 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
686 get_matrix(t->matrix, t->angle, t->xyz, NULL);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
687 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
688
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
689 if (t->children != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
690 t = t->children;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
691 } else if (t->brother != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
692 t = t->brother;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
693 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
694 while (t) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
695 if (t->brother != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
696 t = t->brother;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
697 break;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
698 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
699 if (t->parent == NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
700 t = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
701 break;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
702 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
703 t = t->parent;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
704 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
705 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
706 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
707 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
708 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
709 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
710
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
711 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
712 SceneGraph::set_move_collision(SceneGraphPtr node, move_func new_move,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
713 collision_func new_collision)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
714 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
715 node->move = new_move;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
716 node->collision = new_collision;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
717 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
718
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
719 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
720 SceneGraph::set_move_collision(move_func new_move,
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
721 collision_func new_collision)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
722 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
723 this->move = new_move;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
724 this->collision = new_collision;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
725 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
726
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
727 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
728 SceneGraph::add_next(SceneGraphPtr next)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
729 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
730 /* next のリストの最後に加える */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
731 if (this->next != NULL) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
732 SceneGraphPtr tmp = this->last;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
733 tmp->next = next;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
734 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
735 this->next = next;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
736 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
737
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
738 this->last = next;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
739 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
740
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
741 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
742 * SceneGraph の clone
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
743 * @return clone SceneGraph
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
744 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
745 SceneGraphPtr
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
746 SceneGraph::clone(void) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
747 SceneGraphPtr p = new SceneGraph(this);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
748 return p;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
749 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
750
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
751 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
752 * SceneGraph の clone
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
753 * 予め allocate されてる領域への placement new を行う
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
754 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
755 * @param buf clone 領域
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
756 * @return clone SceneGraph
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
757 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
758 SceneGraphPtr
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
759 SceneGraph::clone(void *buf) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
760 SceneGraphPtr p = new(buf) SceneGraph(this);
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
761 return p;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
762 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
763
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
764 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
765 SceneGraph::remove(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
766 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
767 this->flag_remove = 1;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
768 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
769
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
770 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
771 * tree から node を削除する
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
772 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
773 * @param tree SceneGraphTree
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
774 * @return node削除後の SceneGraphTree
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
775 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
776 SceneGraphPtr
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
777 SceneGraph::realRemoveFromTree(SceneGraphPtr tree)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
778 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
779 SceneGraphPtr node = this;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
780 SceneGraphPtr parent = node->parent;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
781 SceneGraphPtr ret = tree;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
782
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
783 if (parent) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
784 SceneGraphPtr brother = parent->children;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
785 SceneGraphPtr p, p1 = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
786
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
787 p = brother;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
788 if (p) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
789 if (p == node) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
790 parent->children = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
791 parent->lastChild = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
792 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
793 p1 = p->brother;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
794
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
795 while (p1 && p1 != node) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
796 p1 = p1->brother;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
797 p = p->brother;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
798 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
799
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
800 if (p1) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
801 p->brother = p1->brother;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
802
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
803 // node が最後尾なら、lastChild を変更
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
804 if (parent->lastChild == p1) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
805 parent->lastChild = p;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
806 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
807 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
808 // Can't find remove node
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
809 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
810 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
811 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
812 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
813 // 親が居ない = tree root なので
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
814 // NULL を返す
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
815 ret = NULL;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
816 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
817
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
818 return ret;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
819 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
820
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
821 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
822 * list から node を削除する
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
823 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
824 * @param list SceneGraphList
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
825 * @return node削除後の SceneGraphList
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
826 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
827 SceneGraphPtr
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
828 SceneGraph::realRemoveFromList(SceneGraphPtr list)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
829 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
830 SceneGraphPtr node = this;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
831 SceneGraphPtr prev = node->prev;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
832 SceneGraphPtr next = node->next;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
833 SceneGraphPtr ret = list;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
834
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
835 if (prev) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
836 prev->next = next;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
837 } else {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
838 ret = next;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
839 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
840
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
841 if (next) {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
842 next->prev = prev;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
843 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
844
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
845 return ret;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
846 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
847
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
848 int
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
849 SceneGraph::isRemoved(void)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
850 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
851 return flag_remove;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
852 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
853
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
854 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
855 * 平行移動
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
856 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
857 * @param x Ttranslate in the x direction
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
858 * @param y Ttranslate in the y direction
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
859 * @param z Ttranslate in the z direction
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
860 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
861 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
862 SceneGraph::translate(float x, float y, float z)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
863 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
864 this->xyz[0] = x;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
865 this->xyz[1] = y;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
866 this->xyz[2] = z;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
867 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
868
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
869 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
870 * x 軸方向への平行移動
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
871 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
872 * @param x Ttranslate in the x direction
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
873 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
874 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
875 SceneGraph::translateX(float x)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
876 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
877 this->xyz[0] = x;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
878 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
879
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
880 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
881 * y 軸方向への平行移動
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
882 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
883 * @param y Ttranslate in the y direction
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
884 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
885 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
886 SceneGraph::translateY(float y)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
887 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
888 this->xyz[1] = y;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
889 }
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
890
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
891 /**
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
892 * z 軸方向への平行移動
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
893 *
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
894 * @param z Ttranslate in the z direction
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
895 */
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
896 void
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
897 SceneGraph::translateZ(float z)
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
898 {
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
899 this->xyz[2] = z;
55ea4465b1a2 fix test_render
e065746@localhost.localdomain
parents:
diff changeset
900 }