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:
parent
0ce084d8ba
commit
6f7d169123
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue