Mercurial > hg > Game > Cerium
changeset 156:16c3cbbbfc50 draft
fix
author | gongo@gendarme.local |
---|---|
date | Thu, 04 Dec 2008 14:25:00 +0900 |
parents | 79ded2ad7236 |
children | 7bc603ec6111 |
files | TaskManager/Test/test_render/spe/CreateSpan.cpp TaskManager/Test/test_render/spe/DrawSpan.cpp TaskManager/Test/test_render/spe/DrawSpan.h TaskManager/Test/test_render/task/CreateSpan.cpp TaskManager/Test/test_render/task/DrawSpan.cpp TaskManager/Test/test_render/task/DrawSpan.h |
diffstat | 6 files changed, 86 insertions(+), 132 deletions(-) [+] |
line wrap: on
line diff
--- a/TaskManager/Test/test_render/spe/CreateSpan.cpp Thu Dec 04 13:58:41 2008 +0900 +++ b/TaskManager/Test/test_render/spe/CreateSpan.cpp Thu Dec 04 14:25:00 2008 +0900 @@ -82,6 +82,21 @@ v->z = calc(vMax->z - vMin->z, d, d1, vMin->z); } +/** + * テクスチャの座標 (pos1, pos2) を + * TEXTURE_SPLIT_PIXEL x TEXTURE_SPLIT_PIXEL の中に入るように変換 + * + * 例: + * (450, 318) -> 分割されたブロックの (2, 6) になる + */ +static int +get_tex_pos(int pos, int screen) +{ + if (pos < 0) pos = 0; + if (screen - 1 < pos) pos = screen - 1 ; + + return pos % TEXTURE_SPLIT_PIXEL; +} /** * Span の1ドットずつ、必要なテクスチャのブロック(Tile)を求めていく @@ -120,10 +135,9 @@ tex_xpos = (int)((span->tex_width-1) * tex1); tex_ypos = (int)((span->tex_height-1) * tey1); - tile->tix = tex_xpos; - tile->tiy = tex_ypos; + tile->tix = get_tex_pos(tex_xpos, span->tex_width); + tile->tiy = get_tex_pos(tex_ypos, span->tex_height); tile->tile = span->tex_addr; - tile->padding = 1; } else { while (cur_x <= span->length_x) { if (cur_x + MAX_TILE_LIST - 1 < span->length_x) { @@ -146,16 +160,15 @@ tex_ypos = (int)((span->tex_height-1) * tex_y); tile = &tilelist->tileinfo[tilelist->size++]; - tile->tix = tex_xpos; - tile->tiy = tex_ypos; - tile->padding = i; + tile->tix = get_tex_pos(tex_xpos, span->tex_width); + tile->tiy = get_tex_pos(tex_ypos, span->tex_height); int blockX = tex_xpos / TEXTURE_SPLIT_PIXEL; int blockY = tex_ypos / TEXTURE_SPLIT_PIXEL; - int block = blockX + (span->tex_width/TEXTURE_SPLIT_PIXEL)*blockY; + int block = blockX + + (span->tex_width/TEXTURE_SPLIT_PIXEL)*blockY; uint32 *addr = (uint32*)span->tex_addr; tile->tile = (void*)(addr + block*64); - //tile->tile = span->tex_addr; } if (cur_x + MAX_TILE_LIST - 1 < span->length_x) { @@ -343,7 +356,6 @@ // 予めやっておいて、その間に処理、だとちょっと動作が怪しいらしい smanager->mainMem_alloc(TILE_ALLOCATE, sizeof(TileInfoList)); - tmp_tex1 =((i/(div_y)) * vMid10->tex_x) + ( ((div_y - i)/(div_y)) * vMin->tex_x); tmp_tex2 =( (i/(div_y)) * vMid->tex_x) +
--- a/TaskManager/Test/test_render/spe/DrawSpan.cpp Thu Dec 04 13:58:41 2008 +0900 +++ b/TaskManager/Test/test_render/spe/DrawSpan.cpp Thu Dec 04 14:25:00 2008 +0900 @@ -104,32 +104,15 @@ } Uint32 -DrawSpan::get_rgb(int tx, int ty, int tw, int th, void *texture) +DrawSpan::get_rgb(int tx, int ty, void *addr) { Uint8 red, green, blue, alpha; - - if (tx<0) tx = 0; - if (tw-1< tx) tx = tw-1 ; - if (ty<0) ty = 0; - if (th-1< ty) ty = th-1 ; - - void *texture_addr; TilePtr tile; -#if 0 - int blockX = tx / TEXTURE_SPLIT_PIXEL; - int blockY = ty / TEXTURE_SPLIT_PIXEL; - void** addrList = (void**)global_get(TEXTURE2_ID); - - texture_addr = addrList[blockX + (tw/TEXTURE_SPLIT_PIXEL)*blockY]; -#else - texture_addr = texture; -#endif - /** * get,put ϥ֥(HashȤ)äƥ뤫 */ - tile = get(texture_addr); + tile = get(addr); if (tile == NULL) { if (tileList->size >= MAX_TILE) { tileList->init(); @@ -137,9 +120,9 @@ } tile = &tileList->tile[tileList->size]; - tile->texture_addr = texture_addr; + tile->texture_addr = addr; - smanager->dma_load(tile->pixel, (uint32)texture_addr, + smanager->dma_load(tile->pixel, (uint32)addr, sizeof(uint32)*64, TEX_LOAD); int index = put(tile->texture_addr, tile); @@ -159,8 +142,7 @@ smanager->dma_wait(TEX_LOAD); } - char *p = get_pixel(tx%TEXTURE_SPLIT_PIXEL, - ty%TEXTURE_SPLIT_PIXEL, tile->pixel); + char *p = get_pixel(tx, ty, tile->pixel); alpha = 255; red = (Uint8) p[0]; @@ -254,26 +236,18 @@ continue; } +#if 1 + tex_xpos = tilist->tileinfo[0].tix; + tex_ypos = tilist->tileinfo[0].tiy; + texture_image = tilist->tileinfo[0].tile; +#else tex_xpos = (int)((span->tex_width-1) * tex1); tex_ypos = (int)((span->tex_height-1) * tey1); tex_zpos = (int)z; +#endif -#if 1 - if (tex_xpos != tilist->tileinfo[0].tix - && tex_xpos != tilist->tileinfo[0].tix) { - fprintf(stderr, "1: (%3d, %3d), (%3d, %3d)\n", - tex_xpos, tex_ypos, tilist->tileinfo[0].tix, - tilist->tileinfo[0].tiy); - } -#endif - - tex_xpos = tilist->tileinfo[0].tix; - tex_ypos = tilist->tileinfo[0].tiy; - texture_image = tilist->tileinfo[0].tile; - if (zpos < zRow[localx + (rangex * localy)]) { - rgb = get_rgb(tex_xpos, tex_ypos, span->tex_width, - span->tex_height, texture_image); + rgb = get_rgb(tex_xpos, tex_ypos, texture_image); zRow[localx + (rangex * localy)] = zpos; linebuf[localy][localx] = rgb; } @@ -330,34 +304,25 @@ float tex_x, tex_y, tex_z; for (int j = cur_x; j <= cur_x + len; j++) { + TileInfoPtr tinfo = &tilist->tileinfo[j%MAX_TILE_LIST]; localx = getLocalX(x-1+j); tex_z = z*(x_len-1-j)/(x_len-1) + zpos*j/(x_len-1); - + +#if 1 + tex_xpos = tinfo->tix; + tex_ypos = tinfo->tiy; + texture_image = tinfo->tile; +#else tex_x = tex1*(x_len-1-j)/(x_len-1) + tex2*j/(x_len-1); tex_y = tey1*(x_len-1-j)/(x_len-1) + tey2*j/(x_len-1); if (tex_x > 1) tex_x = 1; if (tex_y > 1) tex_y = 1; tex_xpos = (int)((span->tex_width-1) * tex_x); tex_ypos = (int)((span->tex_height-1) * tex_y); +#endif - if (tex_xpos != tilist->tileinfo[j%MAX_TILE_LIST].tix - && tex_xpos != tilist->tileinfo[j%MAX_TILE_LIST].tix) { - fprintf(stderr, "size = %d\n", tilist->size); - fprintf(stderr, "(%3d ..%3d) %d, %d %d\n", - x, x + x_len, js, max_x, j%MAX_TILE_LIST); - fprintf(stderr, "(%3d, %3d), (%3d, %3d)\n", - tex_xpos, tex_ypos, - tilist->tileinfo[j%MAX_TILE_LIST].tix, - tilist->tileinfo[j%MAX_TILE_LIST].tiy); - } - - tex_xpos = tilist->tileinfo[j%MAX_TILE_LIST].tix; - tex_ypos = tilist->tileinfo[j%MAX_TILE_LIST].tiy; - texture_image = tilist->tileinfo[j%MAX_TILE_LIST].tile; - if (tex_z < zRow[localx + (rangex*localy)]) { - rgb = get_rgb(tex_xpos, tex_ypos, span->tex_width, - span->tex_height, texture_image); + rgb = get_rgb(tex_xpos, tex_ypos, texture_image); zRow[localx + (rangex*localy)] = tex_z; linebuf[localy][localx] = rgb; }
--- a/TaskManager/Test/test_render/spe/DrawSpan.h Thu Dec 04 13:58:41 2008 +0900 +++ b/TaskManager/Test/test_render/spe/DrawSpan.h Thu Dec 04 14:25:00 2008 +0900 @@ -41,7 +41,7 @@ void linebuf_init(int *buf, int width, int rgb); char* get_pixel(int tx, int ty, void *texture_image); - Uint32 get_rgb(int tx, int ty, int tw, int th, void *texture); + Uint32 get_rgb(int tx, int ty, void *addr); }; #endif
--- a/TaskManager/Test/test_render/task/CreateSpan.cpp Thu Dec 04 13:58:41 2008 +0900 +++ b/TaskManager/Test/test_render/task/CreateSpan.cpp Thu Dec 04 14:25:00 2008 +0900 @@ -82,6 +82,21 @@ v->z = calc(vMax->z - vMin->z, d, d1, vMin->z); } +/** + * テクスチャの座標 (pos1, pos2) を + * TEXTURE_SPLIT_PIXEL x TEXTURE_SPLIT_PIXEL の中に入るように変換 + * + * 例: + * (450, 318) -> 分割されたブロックの (2, 6) になる + */ +static int +get_tex_pos(int pos, int screen) +{ + if (pos < 0) pos = 0; + if (screen - 1 < pos) pos = screen - 1 ; + + return pos % TEXTURE_SPLIT_PIXEL; +} /** * Span の1ドットずつ、必要なテクスチャのブロック(Tile)を求めていく @@ -120,10 +135,9 @@ tex_xpos = (int)((span->tex_width-1) * tex1); tex_ypos = (int)((span->tex_height-1) * tey1); - tile->tix = tex_xpos; - tile->tiy = tex_ypos; + tile->tix = get_tex_pos(tex_xpos, span->tex_width); + tile->tiy = get_tex_pos(tex_ypos, span->tex_height); tile->tile = span->tex_addr; - tile->padding = 1; } else { while (cur_x <= span->length_x) { if (cur_x + MAX_TILE_LIST - 1 < span->length_x) { @@ -146,16 +160,15 @@ tex_ypos = (int)((span->tex_height-1) * tex_y); tile = &tilelist->tileinfo[tilelist->size++]; - tile->tix = tex_xpos; - tile->tiy = tex_ypos; - tile->padding = i; + tile->tix = get_tex_pos(tex_xpos, span->tex_width); + tile->tiy = get_tex_pos(tex_ypos, span->tex_height); int blockX = tex_xpos / TEXTURE_SPLIT_PIXEL; int blockY = tex_ypos / TEXTURE_SPLIT_PIXEL; - int block = blockX + (span->tex_width/TEXTURE_SPLIT_PIXEL)*blockY; + int block = blockX + + (span->tex_width/TEXTURE_SPLIT_PIXEL)*blockY; uint32 *addr = (uint32*)span->tex_addr; tile->tile = (void*)(addr + block*64); - //tile->tile = span->tex_addr; } if (cur_x + MAX_TILE_LIST - 1 < span->length_x) { @@ -343,7 +356,6 @@ // 予めやっておいて、その間に処理、だとちょっと動作が怪しいらしい smanager->mainMem_alloc(TILE_ALLOCATE, sizeof(TileInfoList)); - tmp_tex1 =((i/(div_y)) * vMid10->tex_x) + ( ((div_y - i)/(div_y)) * vMin->tex_x); tmp_tex2 =( (i/(div_y)) * vMid->tex_x) +
--- a/TaskManager/Test/test_render/task/DrawSpan.cpp Thu Dec 04 13:58:41 2008 +0900 +++ b/TaskManager/Test/test_render/task/DrawSpan.cpp Thu Dec 04 14:25:00 2008 +0900 @@ -104,32 +104,15 @@ } Uint32 -DrawSpan::get_rgb(int tx, int ty, int tw, int th, void *texture) +DrawSpan::get_rgb(int tx, int ty, void *addr) { Uint8 red, green, blue, alpha; - - if (tx<0) tx = 0; - if (tw-1< tx) tx = tw-1 ; - if (ty<0) ty = 0; - if (th-1< ty) ty = th-1 ; - - void *texture_addr; TilePtr tile; -#if 0 - int blockX = tx / TEXTURE_SPLIT_PIXEL; - int blockY = ty / TEXTURE_SPLIT_PIXEL; - void** addrList = (void**)global_get(TEXTURE2_ID); - - texture_addr = addrList[blockX + (tw/TEXTURE_SPLIT_PIXEL)*blockY]; -#else - texture_addr = texture; -#endif - /** * get,put ϥ֥(HashȤ)äƥ뤫 */ - tile = get(texture_addr); + tile = get(addr); if (tile == NULL) { if (tileList->size >= MAX_TILE) { tileList->init(); @@ -137,9 +120,9 @@ } tile = &tileList->tile[tileList->size]; - tile->texture_addr = texture_addr; + tile->texture_addr = addr; - smanager->dma_load(tile->pixel, (uint32)texture_addr, + smanager->dma_load(tile->pixel, (uint32)addr, sizeof(uint32)*64, TEX_LOAD); int index = put(tile->texture_addr, tile); @@ -159,8 +142,7 @@ smanager->dma_wait(TEX_LOAD); } - char *p = get_pixel(tx%TEXTURE_SPLIT_PIXEL, - ty%TEXTURE_SPLIT_PIXEL, tile->pixel); + char *p = get_pixel(tx, ty, tile->pixel); alpha = 255; red = (Uint8) p[0]; @@ -254,26 +236,18 @@ continue; } +#if 1 + tex_xpos = tilist->tileinfo[0].tix; + tex_ypos = tilist->tileinfo[0].tiy; + texture_image = tilist->tileinfo[0].tile; +#else tex_xpos = (int)((span->tex_width-1) * tex1); tex_ypos = (int)((span->tex_height-1) * tey1); tex_zpos = (int)z; +#endif -#if 1 - if (tex_xpos != tilist->tileinfo[0].tix - && tex_xpos != tilist->tileinfo[0].tix) { - fprintf(stderr, "1: (%3d, %3d), (%3d, %3d)\n", - tex_xpos, tex_ypos, tilist->tileinfo[0].tix, - tilist->tileinfo[0].tiy); - } -#endif - - tex_xpos = tilist->tileinfo[0].tix; - tex_ypos = tilist->tileinfo[0].tiy; - texture_image = tilist->tileinfo[0].tile; - if (zpos < zRow[localx + (rangex * localy)]) { - rgb = get_rgb(tex_xpos, tex_ypos, span->tex_width, - span->tex_height, texture_image); + rgb = get_rgb(tex_xpos, tex_ypos, texture_image); zRow[localx + (rangex * localy)] = zpos; linebuf[localy][localx] = rgb; } @@ -330,34 +304,25 @@ float tex_x, tex_y, tex_z; for (int j = cur_x; j <= cur_x + len; j++) { + TileInfoPtr tinfo = &tilist->tileinfo[j%MAX_TILE_LIST]; localx = getLocalX(x-1+j); tex_z = z*(x_len-1-j)/(x_len-1) + zpos*j/(x_len-1); - + +#if 1 + tex_xpos = tinfo->tix; + tex_ypos = tinfo->tiy; + texture_image = tinfo->tile; +#else tex_x = tex1*(x_len-1-j)/(x_len-1) + tex2*j/(x_len-1); tex_y = tey1*(x_len-1-j)/(x_len-1) + tey2*j/(x_len-1); if (tex_x > 1) tex_x = 1; if (tex_y > 1) tex_y = 1; tex_xpos = (int)((span->tex_width-1) * tex_x); tex_ypos = (int)((span->tex_height-1) * tex_y); +#endif - if (tex_xpos != tilist->tileinfo[j%MAX_TILE_LIST].tix - && tex_xpos != tilist->tileinfo[j%MAX_TILE_LIST].tix) { - fprintf(stderr, "size = %d\n", tilist->size); - fprintf(stderr, "(%3d ..%3d) %d, %d %d\n", - x, x + x_len, js, max_x, j%MAX_TILE_LIST); - fprintf(stderr, "(%3d, %3d), (%3d, %3d)\n", - tex_xpos, tex_ypos, - tilist->tileinfo[j%MAX_TILE_LIST].tix, - tilist->tileinfo[j%MAX_TILE_LIST].tiy); - } - - tex_xpos = tilist->tileinfo[j%MAX_TILE_LIST].tix; - tex_ypos = tilist->tileinfo[j%MAX_TILE_LIST].tiy; - texture_image = tilist->tileinfo[j%MAX_TILE_LIST].tile; - if (tex_z < zRow[localx + (rangex*localy)]) { - rgb = get_rgb(tex_xpos, tex_ypos, span->tex_width, - span->tex_height, texture_image); + rgb = get_rgb(tex_xpos, tex_ypos, texture_image); zRow[localx + (rangex*localy)] = tex_z; linebuf[localy][localx] = rgb; }
--- a/TaskManager/Test/test_render/task/DrawSpan.h Thu Dec 04 13:58:41 2008 +0900 +++ b/TaskManager/Test/test_render/task/DrawSpan.h Thu Dec 04 14:25:00 2008 +0900 @@ -41,7 +41,7 @@ void linebuf_init(int *buf, int width, int rgb); char* get_pixel(int tx, int ty, void *texture_image); - Uint32 get_rgb(int tx, int ty, int tw, int th, void *texture); + Uint32 get_rgb(int tx, int ty, void *addr); }; #endif