Mercurial > hg > Game > Cerium
changeset 166:8831c058a1ff draft
fix
author | gongo@localhost.localdomain |
---|---|
date | Tue, 09 Dec 2008 11:53:51 +0900 |
parents | 121b08b64b44 |
children | 508beb59e0eb |
files | TaskManager/Test/test_render/spe/DrawSpan.cpp TaskManager/Test/test_render/spe/DrawSpan.h TaskManager/Test/test_render/task/DrawSpan.cpp TaskManager/Test/test_render/task/DrawSpan.h |
diffstat | 4 files changed, 41 insertions(+), 26 deletions(-) [+] |
line wrap: on
line diff
--- a/TaskManager/Test/test_render/spe/DrawSpan.cpp Tue Dec 09 11:15:37 2008 +0900 +++ b/TaskManager/Test/test_render/spe/DrawSpan.cpp Tue Dec 09 11:53:51 2008 +0900 @@ -8,7 +8,6 @@ #define SPAN_PACK_LOAD 0 #define TEX_LOAD 1 -#define TILE_INFO_LOAD 2 SchedDefineTask(DrawSpan); @@ -157,13 +156,13 @@ char* -DrawSpan::get_pixel(int tx, int ty, void *texture_image) +DrawSpan::get_pixel(int tx, int ty, uint32 *texture_image) { - return (char*)texture_image+(4*((TEXTURE_SPLIT_PIXEL)*ty+tx)); + return (char*)(texture_image+((TEXTURE_SPLIT_PIXEL)*ty+tx)); } Uint32 -DrawSpan::get_rgb(int tx, int ty, void *addr) +DrawSpan::get_rgb(int tx, int ty, uint32 *addr) { Uint8 red, green, blue, alpha; TilePtr tile; @@ -265,10 +264,17 @@ float tey1 = span->tex_y1; float tey2 = span->tex_y2; + /** + * Span が持つ 1 pixel 毎の + * テクスチャの座標 + */ int tex_xpos; int tex_ypos; - int tex_zpos; + /** + * (tex_xpos, tex_ypos) の、ブロック内(上の図参照)での座標と + * そのブロックのアドレス(MainMemory) + */ int tex_localx; int tex_localy; uint32 *tex_addr; @@ -290,14 +296,13 @@ tex_xpos = (int)((span->tex_width-1) * tex1); tex_ypos = (int)((span->tex_height-1) * tey1); - tex_zpos = (int)z; if (zpos < zRow[localx + (rangex * localy)]) { + tex_addr = getTile(tex_xpos, tex_ypos, + span->tex_width, span->tex_addr); tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; - tex_addr = getTile(tex_xpos, tex_ypos, - span->tex_width, span->tex_addr); - + rgb = get_rgb(tex_localx, tex_localy, tex_addr); zRow[localx + (rangex * localy)] = zpos; @@ -326,10 +331,10 @@ tex_ypos = (int)((span->tex_height-1) * tex_y); if (tex_z < zRow[localx + (rangex*localy)]) { + tex_addr = getTile(tex_xpos, tex_ypos, + span->tex_width, span->tex_addr); tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; - tex_addr = getTile(tex_xpos, tex_ypos, - span->tex_width, span->tex_addr); rgb = get_rgb(tex_localx, tex_localy, tex_addr);
--- a/TaskManager/Test/test_render/spe/DrawSpan.h Tue Dec 09 11:15:37 2008 +0900 +++ b/TaskManager/Test/test_render/spe/DrawSpan.h Tue Dec 09 11:53:51 2008 +0900 @@ -40,8 +40,8 @@ float* zRow_init(int w, int h); 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, void *addr); + char* get_pixel(int tx, int ty, uint32 *texture_image); + Uint32 get_rgb(int tx, int ty, uint32 *addr); }; #endif
--- a/TaskManager/Test/test_render/task/DrawSpan.cpp Tue Dec 09 11:15:37 2008 +0900 +++ b/TaskManager/Test/test_render/task/DrawSpan.cpp Tue Dec 09 11:53:51 2008 +0900 @@ -8,7 +8,6 @@ #define SPAN_PACK_LOAD 0 #define TEX_LOAD 1 -#define TILE_INFO_LOAD 2 SchedDefineTask(DrawSpan); @@ -157,13 +156,13 @@ char* -DrawSpan::get_pixel(int tx, int ty, void *texture_image) +DrawSpan::get_pixel(int tx, int ty, uint32 *texture_image) { - return (char*)texture_image+(4*((TEXTURE_SPLIT_PIXEL)*ty+tx)); + return (char*)(texture_image+((TEXTURE_SPLIT_PIXEL)*ty+tx)); } Uint32 -DrawSpan::get_rgb(int tx, int ty, void *addr) +DrawSpan::get_rgb(int tx, int ty, uint32 *addr) { Uint8 red, green, blue, alpha; TilePtr tile; @@ -265,10 +264,17 @@ float tey1 = span->tex_y1; float tey2 = span->tex_y2; + /** + * Span が持つ 1 pixel 毎の + * テクスチャの座標 + */ int tex_xpos; int tex_ypos; - int tex_zpos; + /** + * (tex_xpos, tex_ypos) の、ブロック内(上の図参照)での座標と + * そのブロックのアドレス(MainMemory) + */ int tex_localx; int tex_localy; uint32 *tex_addr; @@ -290,14 +296,13 @@ tex_xpos = (int)((span->tex_width-1) * tex1); tex_ypos = (int)((span->tex_height-1) * tey1); - tex_zpos = (int)z; if (zpos < zRow[localx + (rangex * localy)]) { + tex_addr = getTile(tex_xpos, tex_ypos, + span->tex_width, span->tex_addr); tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; - tex_addr = getTile(tex_xpos, tex_ypos, - span->tex_width, span->tex_addr); - + rgb = get_rgb(tex_localx, tex_localy, tex_addr); zRow[localx + (rangex * localy)] = zpos; @@ -315,16 +320,21 @@ 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_x < 0) tex_x = 0; if (tex_y > 1) tex_y = 1; + if (tex_y < 0) tex_y = 0; tex_xpos = (int)((span->tex_width-1) * tex_x); tex_ypos = (int)((span->tex_height-1) * tex_y); if (tex_z < zRow[localx + (rangex*localy)]) { + tex_addr = getTile(tex_xpos, tex_ypos, + span->tex_width, span->tex_addr); tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; - tex_addr = getTile(tex_xpos, tex_ypos, - span->tex_width, span->tex_addr); rgb = get_rgb(tex_localx, tex_localy, tex_addr);
--- a/TaskManager/Test/test_render/task/DrawSpan.h Tue Dec 09 11:15:37 2008 +0900 +++ b/TaskManager/Test/test_render/task/DrawSpan.h Tue Dec 09 11:53:51 2008 +0900 @@ -40,8 +40,8 @@ float* zRow_init(int w, int h); 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, void *addr); + char* get_pixel(int tx, int ty, uint32 *texture_image); + Uint32 get_rgb(int tx, int ty, uint32 *addr); }; #endif