Mercurial > hg > Game > Cerium
changeset 174:2c7d9057dd5d draft
getScale()、getTapestry から、span->length に適切なテクスチャの選択に成功
author | gongo@localhost.localdomain |
---|---|
date | Fri, 12 Dec 2008 12:23:20 +0900 |
parents | 1e62bd02f820 |
children | 1268e1a9a7db |
files | TaskManager/Test/test_render/Makefile.def TaskManager/Test/test_render/SceneGraph.cpp TaskManager/Test/test_render/polygon_pack.h TaskManager/Test/test_render/spe/CreatePolygon.cpp TaskManager/Test/test_render/spe/CreateSpan.cpp TaskManager/Test/test_render/spe/CreateSpan.h TaskManager/Test/test_render/spe/DrawSpan.cpp TaskManager/Test/test_render/sys.cpp TaskManager/Test/test_render/task/CreatePolygon.cpp TaskManager/Test/test_render/task/CreatePolygonFromSceneGraph.cpp TaskManager/Test/test_render/task/CreateSpan.cpp TaskManager/Test/test_render/task/CreateSpan.h TaskManager/Test/test_render/task/DrawSpan.cpp TaskManager/Test/test_render/texture.h |
diffstat | 14 files changed, 184 insertions(+), 74 deletions(-) [+] |
line wrap: on
line diff
--- a/TaskManager/Test/test_render/Makefile.def Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/Makefile.def Fri Dec 12 12:23:20 2008 +0900 @@ -12,7 +12,7 @@ #CERIUM = ../../.. CC = g++ -CFLAGS = -O0 -g -Wall# -DDEBUG +CFLAGS = -O9 -g -Wall# -DDEBUG INCLUDE = -I$(CERIUM)/include/TaskManager -I. LIBS = -L$(CERIUM)/TaskManager \ No newline at end of file
--- a/TaskManager/Test/test_render/SceneGraph.cpp Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/SceneGraph.cpp Fri Dec 12 12:23:20 2008 +0900 @@ -324,13 +324,13 @@ } uint32 *tex_dest; + int scale = 1; { int t = 0; int tex_w = texture_image->w; int tex_h = texture_image->h; Uint32 *tex_src = (Uint32*)texture_image->pixels; - int scale = 1; int scale_cnt; int cur_w = tex_w; int cur_h = tex_h; @@ -349,11 +349,10 @@ */ while (cur_w % TEXTURE_SPLIT_PIXEL == 0 && cur_h % TEXTURE_SPLIT_PIXEL == 0) { - printf("(%3d, %3d) = %4d\n", cur_w, cur_h, cur_w*cur_h); all_pixel_num += cur_w*cur_h; - cur_w >>= 1; + cur_w >>= 1; /* cur_w /= 2 */ cur_h >>= 1; - scale <<= 1; + scale <<= 1; /* scale *= 2 */ } scale >>= 1; @@ -361,8 +360,6 @@ tex_dest = (uint32*)manager->malloc(sizeof(int)*all_pixel_num); - printf("scale = %d, all = %d\n", scale, all_pixel_num); - int diff = TEXTURE_SPLIT_PIXEL; int p_diff = 1; while (scale_cnt) { @@ -376,7 +373,7 @@ } } } - + diff <<= 1; p_diff <<= 1; scale_cnt >>= 1; @@ -387,14 +384,16 @@ list[id_count-1].t_h = texture_image->h; list[id_count-1].pixels_orig = (Uint32*)texture_image->pixels; list[id_count-1].pixels = tex_dest; + list[id_count-1].scale_max = scale; texture_id = id_count-1; texture_info.t_w = texture_image->w; texture_info.t_h = texture_image->h; texture_info.pixels_orig = (Uint32*)texture_image->pixels; texture_info.pixels = tex_dest; + texture_info.scale_max = scale; - if(unlink(image_name)) + if (unlink(image_name)) { cout << "unlink error\n"; } @@ -411,6 +410,7 @@ texture_info.t_h = list[tex_id].t_h;; texture_info.pixels_orig = list[tex_id].pixels_orig; texture_info.pixels = list[tex_id].pixels; + texture_info.scale_max = list[tex_id].scale_max; } } }
--- a/TaskManager/Test/test_render/polygon_pack.h Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/polygon_pack.h Fri Dec 12 12:23:20 2008 +0900 @@ -13,16 +13,22 @@ float z; float tex_x; float tex_y; -}VertexPack, *VertexPackPtr; +} VertexPack, *VertexPackPtr; // 20 byte typedef struct TrianglePack { - uint32 *tex_addr; - int tex_width, tex_height; + struct { + uint32 *addr; + int width; + int height; + int scale_max; + } tex_info; + VertexPack ver1; VertexPack ver2; VertexPack ver3; -} TrianglePack, *TrianglePackPtr; + +} TrianglePack, *TrianglePackPtr; //4*4 + 20*3 = 76 typedef struct PolygonPack { @@ -31,13 +37,14 @@ int light_pos[3]; int light_rgb[3]; }info; - TrianglePack tri[MAX_SIZE_TRIANGLE]; // Variable length array + + TrianglePack tri[MAX_SIZE_TRIANGLE]; PolygonPack* next; void init(void) { info.size = 0; - next = 0; + next = 0; } void clear(void) { @@ -52,11 +59,10 @@ } this->init(); } -} PolygonPack, *PolygonPackPtr; +} PolygonPack, *PolygonPackPtr; // 4*7 + 76*128 + 4 = 9760 typedef struct PolygonPackList { int size; - //PolygonPack *list[6]; PolygonPack *list; } PolygonPackList;
--- a/TaskManager/Test/test_render/spe/CreatePolygon.cpp Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/spe/CreatePolygon.cpp Fri Dec 12 12:23:20 2008 +0900 @@ -147,13 +147,13 @@ triangle->ver3.tex_y = node->texture[nt+4+1]; #if 1 - triangle->tex_addr = node->tex_addr; - triangle->tex_width = node->tex_width; - triangle->tex_height = node->tex_height; + triangle->tex_info.addr = node->tex_addr; + triangle->tex_info.width = node->tex_width; + triangle->tex_info.height = node->tex_height; #else - triangle->tex_addr = node->texture_info.pixels; - triangle->tex_width = node->texture_info.t_w; - triangle->tex_height = node->texture_info.t_h; + triangle->tex_info.addr = node->texture_info.pixels; + triangle->tex_info.width = node->texture_info.t_w; + triangle->tex_info.height = node->texture_info.t_h; #endif }
--- a/TaskManager/Test/test_render/spe/CreateSpan.cpp Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/spe/CreateSpan.cpp Fri Dec 12 12:23:20 2008 +0900 @@ -124,6 +124,51 @@ } /** + * 与えられた scale から、実際に使うテクスチャの Tapestry を選択する + * + * テクスチャは、オリジナルのサイズから、可能なかぎり 1/2 で縮小していき、 + * 下の図の様に連続した領域に入れられる + * + * Tapestry (1) + * +---+---+---+---+ + * | 0 | 1 | 2 | 3 | + * +---+---+---+---+ + * | 4 | 5 | 6 | 7 | (2) + * +---+---+---+---+ +---+---+ + * | 8 | 9 | 10| 11| | 16| 17| (3) + * +---+---+---+---+ +---+---+ +---+ + * | 12| 13| 14| 15| | 18| 19| | 20| + * +---+---+---+---+ +---+---+ +---| + * + * (1) (2) (3) + * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+ + * | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | * | * | * | 14| 15| 16| 17| 18| 19| 20| + * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+ + * + * scale の値から、各 Tapestry の先頭アドレスを返す + * + * @param[in] tw Width of texture + * @param[in] th Height of texture + * @param[in] scale テクスチャの縮小率 (= 2^n) + * @param[in] addr_top テクスチャの先頭アドレス (上の図での (1) + * @return scale に対応する Tapestry のアドレス (上の図での (1) or (2) or(3) + */ +static uint32* +getTapestry(int tw, int th, int scale, uint32 *addr_top) +{ + int index = 0; + + for (int s = 1; s < scale; s <<= 1) { + index += tw*th; + tw >>= 1; /* tw /= 2 */ + th >>= 1; + } + + return addr_top + index; +} + + +/** * span の width,height と texture の width,height を比べて * span を描画する際に使う texture の比率を求める * @@ -131,14 +176,14 @@ * @param height Height of span * @param tex_width Width of 1/1 texture that span use * @param tex_height Height of 1/1 texture that span use + * @param scale_max この Span で使う texture の最大縮小率 + * 計算結果が scale_max 以上になるのを防ぐ * @return 描画に使う texture の比率 * width と height は 1/scale の画像を使う * - * @todo scale_max を設定するべき - * 縮小は 1/8 までしかやってなくて、scale が 16 になる場合もある */ static int -getScale(int width, int height, int tex_width, int tex_height) +getScale(int width, int height, int tex_width, int tex_height, int scale_max) { int base, tex_base; int scale = 1; @@ -163,7 +208,7 @@ } } - return scale; + return (scale > scale_max) ? scale_max : scale; } /** @@ -186,6 +231,7 @@ CreateSpan::half_triangle(SpanPackPtr *spackList, int charge_y_top, int charge_y_end, uint32 *tex_addr, int tex_width, int tex_height, + int tex_scale_max, VertexPack *vMin,VertexPack *vMid,VertexPack *vMid10, int y_length) { @@ -357,9 +403,6 @@ Span *span = &spack->span[spack->info.size++]; - span->tex_addr = tex_addr; - span->tex_width = tex_width; - span->tex_height = tex_height; span->x = x; span->y = y; span->length_x = length; @@ -371,7 +414,15 @@ span->tex_y2 = end_tex_y; int scale = getScale(span->length_x, y_length, - span->tex_width, span->tex_height); + span->tex_width, span->tex_height, tex_scale_max); + + //scale = (16 > tex_scale_max) ? tex_scale_max : 16; + + uint32 *tapestry = getTapestry(tex_width, tex_height, scale, tex_addr); + + span->tex_addr = tapestry; + span->tex_width = tex_width/scale; + span->tex_height = tex_height/scale; } } @@ -469,13 +520,17 @@ * 二つの Triangle に分けている */ half_triangle(spackList, charge_y_top, charge_y_end, - triPack->tex_addr, triPack->tex_width, - triPack->tex_height, vMin, vMid, vMid10, - (int)(vMax->y - vMin->y)); + triPack->tex_info.addr, + triPack->tex_info.width, + triPack->tex_info.height, + triPack->tex_info.scale_max, + vMin, vMid, vMid10, (int)(vMax->y - vMin->y)); half_triangle(spackList, charge_y_top, charge_y_end, - pp->tri[0].tex_addr, pp->tri[0].tex_width, - pp->tri[0].tex_height, vMax, vMid, vMid10, - (int)(vMax->y - vMin->y)); + pp->tri[0].tex_info.addr, + pp->tri[0].tex_info.width, + pp->tri[0].tex_info.height, + pp->tri[0].tex_info.scale_max, + vMax, vMid, vMid10, (int)(vMax->y - vMin->y)); } smanager->dma_wait(POLYGON_PACK_LOAD);
--- a/TaskManager/Test/test_render/spe/CreateSpan.h Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/spe/CreateSpan.h Fri Dec 12 12:23:20 2008 +0900 @@ -21,6 +21,7 @@ void half_triangle(SpanPackPtr *spackList, int charge_y_top, int charge_y_end, uint32 *tex_addr, int tex_width, int tex_height, + int tex_scale_max, VertexPack *vMin,VertexPack *vMid,VertexPack *vMid1, int y_length); void setTileInfoList(SpanPtr span);
--- a/TaskManager/Test/test_render/spe/DrawSpan.cpp Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/spe/DrawSpan.cpp Fri Dec 12 12:23:20 2008 +0900 @@ -100,7 +100,6 @@ Uint32 DrawSpan::get_rgb(int tx, int ty, uint32 *addr) { - Uint8 red, green, blue, alpha; TilePtr tile; tile = hash->get(addr);
--- a/TaskManager/Test/test_render/sys.cpp Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/sys.cpp Fri Dec 12 12:23:20 2008 +0900 @@ -36,7 +36,7 @@ float cosz = cos(radz); matrix[0] = cosz*cosy+sinz*sinx*siny; - matrix[1] =sinz*cosx; + matrix[1] = sinz*cosx; matrix[2] = -cosz*siny+sinz*sinx*cosy; matrix[3] = 0; matrix[4] = -sinz*cosy+cosz*sinx*siny;
--- a/TaskManager/Test/test_render/task/CreatePolygon.cpp Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/task/CreatePolygon.cpp Fri Dec 12 12:23:20 2008 +0900 @@ -147,13 +147,13 @@ triangle->ver3.tex_y = node->texture[nt+4+1]; #if 1 - triangle->tex_addr = node->tex_addr; - triangle->tex_width = node->tex_width; - triangle->tex_height = node->tex_height; + triangle->tex_info.addr = node->tex_addr; + triangle->tex_info.width = node->tex_width; + triangle->tex_info.height = node->tex_height; #else - triangle->tex_addr = node->texture_info.pixels; - triangle->tex_width = node->texture_info.t_w; - triangle->tex_height = node->texture_info.t_h; + triangle->tex_info.addr = node->texture_info.pixels; + triangle->tex_info.width = node->texture_info.t_w; + triangle->tex_info.height = node->texture_info.t_h; #endif }
--- a/TaskManager/Test/test_render/task/CreatePolygonFromSceneGraph.cpp Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/task/CreatePolygonFromSceneGraph.cpp Fri Dec 12 12:23:20 2008 +0900 @@ -117,9 +117,10 @@ triangle->ver3.tex_x = sg->data[(i+2)*3 + sg->size*6]; triangle->ver3.tex_y = sg->data[(i+2)*3 + sg->size*6+1]; - triangle->tex_addr = sg->texture_info.pixels; - triangle->tex_width = sg->texture_info.t_w; - triangle->tex_height = sg->texture_info.t_h; + triangle->tex_info.addr = sg->texture_info.pixels; + triangle->tex_info.width = sg->texture_info.t_w; + triangle->tex_info.height = sg->texture_info.t_h; + triangle->tex_info.scale_max = sg->texture_info.scale_max; }
--- a/TaskManager/Test/test_render/task/CreateSpan.cpp Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/task/CreateSpan.cpp Fri Dec 12 12:23:20 2008 +0900 @@ -124,6 +124,51 @@ } /** + * 与えられた scale から、実際に使うテクスチャの Tapestry を選択する + * + * テクスチャは、オリジナルのサイズから、可能なかぎり 1/2 で縮小していき、 + * 下の図の様に連続した領域に入れられる + * + * Tapestry (1) + * +---+---+---+---+ + * | 0 | 1 | 2 | 3 | + * +---+---+---+---+ + * | 4 | 5 | 6 | 7 | (2) + * +---+---+---+---+ +---+---+ + * | 8 | 9 | 10| 11| | 16| 17| (3) + * +---+---+---+---+ +---+---+ +---+ + * | 12| 13| 14| 15| | 18| 19| | 20| + * +---+---+---+---+ +---+---+ +---| + * + * (1) (2) (3) + * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+ + * | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | * | * | * | 14| 15| 16| 17| 18| 19| 20| + * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+ + * + * scale の値から、各 Tapestry の先頭アドレスを返す + * + * @param[in] tw Width of texture + * @param[in] th Height of texture + * @param[in] scale テクスチャの縮小率 (= 2^n) + * @param[in] addr_top テクスチャの先頭アドレス (上の図での (1) + * @return scale に対応する Tapestry のアドレス (上の図での (1) or (2) or(3) + */ +static uint32* +getTapestry(int tw, int th, int scale, uint32 *addr_top) +{ + int index = 0; + + for (int s = 1; s < scale; s <<= 1) { + index += tw*th; + tw >>= 1; /* tw /= 2 */ + th >>= 1; + } + + return addr_top + index; +} + + +/** * span の width,height と texture の width,height を比べて * span を描画する際に使う texture の比率を求める * @@ -131,14 +176,14 @@ * @param height Height of span * @param tex_width Width of 1/1 texture that span use * @param tex_height Height of 1/1 texture that span use + * @param scale_max この Span で使う texture の最大縮小率 + * 計算結果が scale_max 以上になるのを防ぐ * @return 描画に使う texture の比率 * width と height は 1/scale の画像を使う * - * @todo scale_max を設定するべき - * 縮小は 1/8 までしかやってなくて、scale が 16 になる場合もある */ static int -getScale(int width, int height, int tex_width, int tex_height) +getScale(int width, int height, int tex_width, int tex_height, int scale_max) { int base, tex_base; int scale = 1; @@ -163,7 +208,7 @@ } } - return scale; + return (scale > scale_max) ? scale_max : scale; } /** @@ -186,6 +231,7 @@ CreateSpan::half_triangle(SpanPackPtr *spackList, int charge_y_top, int charge_y_end, uint32 *tex_addr, int tex_width, int tex_height, + int tex_scale_max, VertexPack *vMin,VertexPack *vMid,VertexPack *vMid10, int y_length) { @@ -357,9 +403,6 @@ Span *span = &spack->span[spack->info.size++]; - span->tex_addr = tex_addr; - span->tex_width = tex_width; - span->tex_height = tex_height; span->x = x; span->y = y; span->length_x = length; @@ -371,7 +414,15 @@ span->tex_y2 = end_tex_y; int scale = getScale(span->length_x, y_length, - span->tex_width, span->tex_height); + span->tex_width, span->tex_height, tex_scale_max); + + //scale = (16 > tex_scale_max) ? tex_scale_max : 16; + + uint32 *tapestry = getTapestry(tex_width, tex_height, scale, tex_addr); + + span->tex_addr = tapestry; + span->tex_width = tex_width/scale; + span->tex_height = tex_height/scale; } } @@ -469,13 +520,17 @@ * 二つの Triangle に分けている */ half_triangle(spackList, charge_y_top, charge_y_end, - triPack->tex_addr, triPack->tex_width, - triPack->tex_height, vMin, vMid, vMid10, - (int)(vMax->y - vMin->y)); + triPack->tex_info.addr, + triPack->tex_info.width, + triPack->tex_info.height, + triPack->tex_info.scale_max, + vMin, vMid, vMid10, (int)(vMax->y - vMin->y)); half_triangle(spackList, charge_y_top, charge_y_end, - pp->tri[0].tex_addr, pp->tri[0].tex_width, - pp->tri[0].tex_height, vMax, vMid, vMid10, - (int)(vMax->y - vMin->y)); + pp->tri[0].tex_info.addr, + pp->tri[0].tex_info.width, + pp->tri[0].tex_info.height, + pp->tri[0].tex_info.scale_max, + vMax, vMid, vMid10, (int)(vMax->y - vMin->y)); } smanager->dma_wait(POLYGON_PACK_LOAD);
--- a/TaskManager/Test/test_render/task/CreateSpan.h Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/task/CreateSpan.h Fri Dec 12 12:23:20 2008 +0900 @@ -21,6 +21,7 @@ void half_triangle(SpanPackPtr *spackList, int charge_y_top, int charge_y_end, uint32 *tex_addr, int tex_width, int tex_height, + int tex_scale_max, VertexPack *vMin,VertexPack *vMid,VertexPack *vMid1, int y_length); void setTileInfoList(SpanPtr span);
--- a/TaskManager/Test/test_render/task/DrawSpan.cpp Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/task/DrawSpan.cpp Fri Dec 12 12:23:20 2008 +0900 @@ -100,7 +100,6 @@ Uint32 DrawSpan::get_rgb(int tx, int ty, uint32 *addr) { - Uint8 red, green, blue, alpha; TilePtr tile; tile = hash->get(addr);
--- a/TaskManager/Test/test_render/texture.h Thu Dec 11 20:17:01 2008 +0900 +++ b/TaskManager/Test/test_render/texture.h Fri Dec 12 12:23:20 2008 +0900 @@ -7,18 +7,11 @@ GLuint SDL_GL_LoadTexture(SDL_Surface *surface, GLfloat *texcoord) #endif -#if 0 -struct texture_tmp{ - Uint32 tx128[SSIZE]; - Uint32 tx64[SS64]; - Uint32 tx32[SS32]; -}; -#endif - struct texture_list { - int t_w, t_h; - Uint32 *pixels_orig; - Uint32 *pixels; + int t_w, t_h; + Uint32 *pixels_orig; + Uint32 *pixels; + int scale_max; }; #endif