From 391f27736076deb704a2ab2a4fefb5c24eacd3b6 Mon Sep 17 00:00:00 2001 From: nitsuja Date: Sat, 10 Oct 2009 06:14:36 +0000 Subject: [PATCH] fixed backface culling of non-convex quads --- desmume/src/rasterize.cpp | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/desmume/src/rasterize.cpp b/desmume/src/rasterize.cpp index 63f6174dc..9ea3a9241 100644 --- a/desmume/src/rasterize.cpp +++ b/desmume/src/rasterize.cpp @@ -1288,6 +1288,7 @@ static void SoftRastRender() //this should be moved to gfx3d, but first we need to redo the way the lists are built //because it is too convoluted right now. //(must we throw out verts if a poly gets backface culled? if not, then it might be easier) +#if 0 //TODO - is this good enough for quads and other shapes? we think so. float ab[2], ac[2]; Vector2Copy(ab, verts[1].coord); @@ -1296,6 +1297,18 @@ static void SoftRastRender() Vector2Subtract(ac, verts[0].coord); float cross = Vector2Cross(ab, ac); polyAttr.backfacing = (cross>0); +#else + // actually, the answer to the above question seems to be NO, it's not good enough, + // because we have to support somewhat non-convex polygons (see NSMB world map 1st screen). + // this version should handle those cases better. + int n = type - 1; + float facing = (verts[0].y + verts[n].y) * (verts[0].x - verts[n].x) + + (verts[1].y + verts[0].y) * (verts[1].x - verts[0].x) + + (verts[2].y + verts[1].y) * (verts[2].x - verts[1].x); + for(int i = 2; i < n; i++) + facing += (verts[i+1].y + verts[i].y) * (verts[i+1].x - verts[i].x); + polyAttr.backfacing = (facing < 0); +#endif if(!polyAttr.isVisible(polyAttr.backfacing)) { culled++;