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