0.9.6: rasterizer: add workaround for line poly. However, it's commented out since it's incomplete and also causes another glitch.

This commit is contained in:
gocha 2010-12-22 11:30:32 +00:00
parent 0ce084d8ba
commit 6f7d169123
2 changed files with 49 additions and 10 deletions

View File

@ -814,9 +814,8 @@ static void GL_ReadFramebuffer()
// "Workaround" for line poly // "Workaround" for line poly
static bool isLinePoly(int listIndex) static bool isLinePoly(POLY *poly)
{ {
POLY *poly = &gfx3d.polylist->list[gfx3d.indexlist.list[listIndex]];
int type = poly->type; int type = poly->type;
VERT *vert1, *vert2; VERT *vert1, *vert2;
@ -972,7 +971,7 @@ static void OGLRender()
lastViewport = poly->viewport; lastViewport = poly->viewport;
} }
if (isLinePoly(i)) if (isLinePoly(poly))
glBegin(GL_LINE_LOOP); glBegin(GL_LINE_LOOP);
else else
glBegin(GL_TRIANGLES); glBegin(GL_TRIANGLES);

View File

@ -223,16 +223,30 @@ FORCEINLINE edge_fx_fl::edge_fx_fl(int Top, int Bottom, VERT** verts, bool& fail
Y = Ceil28_4((fixed28_4)verts[Top]->y); Y = Ceil28_4((fixed28_4)verts[Top]->y);
int YEnd = Ceil28_4((fixed28_4)verts[Bottom]->y); int YEnd = Ceil28_4((fixed28_4)verts[Bottom]->y);
Height = YEnd - Y; Height = YEnd - Y;
X = Ceil28_4((fixed28_4)verts[Top]->x);
int XEnd = Ceil28_4((fixed28_4)verts[Bottom]->x);
int Width = XEnd - X; // can be negative
if(Height) // even if Height == 0, give some info for horizontal line poly
if(Height != 0 || Width != 0)
{ {
long dN = long(verts[Bottom]->y - verts[Top]->y); long dN = long(verts[Bottom]->y - verts[Top]->y);
long dM = long(verts[Bottom]->x - verts[Top]->x); long dM = long(verts[Bottom]->x - verts[Top]->x);
if (dN != 0)
{
long InitialNumerator = (long)(dM*16*Y - dM*verts[Top]->y + dN*verts[Top]->x - 1 + dN*16); long InitialNumerator = (long)(dM*16*Y - dM*verts[Top]->y + dN*verts[Top]->x - 1 + dN*16);
FloorDivMod(InitialNumerator,dN*16,X,ErrorTerm,failure); FloorDivMod(InitialNumerator,dN*16,X,ErrorTerm,failure);
FloorDivMod(dM*16,dN*16,XStep,Numerator,failure); FloorDivMod(dM*16,dN*16,XStep,Numerator,failure);
Denominator = dN*16; Denominator = dN*16;
}
else
{
XStep = Width;
Numerator = 0;
ErrorTerm = 0;
Denominator = 1;
failure = false;
}
float YPrestep = Fixed28_4ToFloat((fixed28_4)(Y*16 - verts[Top]->y)); float YPrestep = Fixed28_4ToFloat((fixed28_4)(Y*16 - verts[Top]->y));
float XPrestep = Fixed28_4ToFloat((fixed28_4)(X*16 - verts[Top]->x)); float XPrestep = Fixed28_4ToFloat((fixed28_4)(X*16 - verts[Top]->x));
@ -296,6 +310,7 @@ static FORCEINLINE void alphaBlend(FragmentColor & dst, const FragmentColor & sr
} }
} }
// TODO: wire-frame
struct PolyAttr struct PolyAttr
{ {
u32 val; u32 val;
@ -681,6 +696,22 @@ public:
int XStart = pLeft->X; int XStart = pLeft->X;
int width = pRight->X - XStart; int width = pRight->X - XStart;
// workaround for vertical/slant line poly
// it seems to cause another issue though
//if (width == 0)
//{
// int leftWidth = pLeft->XStep;
// if (pLeft->ErrorTerm + pLeft->Numerator >= pLeft->Denominator)
// leftWidth++;
// int rightWidth = pRight->XStep;
// if (pRight->ErrorTerm + pRight->Numerator >= pRight->Denominator)
// rightWidth++;
// width = max(1, min(abs(leftWidth), abs(rightWidth)));
//
// if (XStart + width > 256)
// width = max(0, 256 - XStart);
//}
//these are the starting values, taken from the left edge //these are the starting values, taken from the left edge
float invw = pLeft->invw.curr; float invw = pLeft->invw.curr;
float u = pLeft->u.curr; float u = pLeft->u.curr;
@ -752,6 +783,15 @@ public:
bool first=true; bool first=true;
static int runctr=0; static int runctr=0;
runctr++; runctr++;
//HACK: special handling for horizontal line poly
//Instead of line, this will cause other notable issue.
//if (left->Height == 0 && right->Height == 0)
//{
// bool draw = (!SLI || (left->Y & SLI_MASK) == SLI_VALUE);
// if(draw) drawscanline(left,right);
//}
while(Height--) { while(Height--) {
bool draw = (!SLI || (left->Y & SLI_MASK) == SLI_VALUE); bool draw = (!SLI || (left->Y & SLI_MASK) == SLI_VALUE);
if(draw) drawscanline(left,right); if(draw) drawscanline(left,right);