#include "qpolygonscanner.h"
#include "qpointarray.h"
#include <stdlib.h>
Clases |
struct | BRESINFO |
struct | _EdgeTableEntry |
struct | _ScanLineList |
struct | EdgeTable |
struct | _ScanLineListBlock |
struct | DDXPointRec |
'defines' |
#define | BRESINITPGON(dy, x1, x2, xStart, d, m, m1, incr1, incr2) |
#define | BRESINCRPGON(d, minval, m, m1, incr1, incr2) |
#define | BRESINITPGONSTRUCT(dmaj, min1, min2, bres) |
#define | BRESINCRPGONSTRUCT(bres) BRESINCRPGON(bres.d, bres.minor, bres.m, bres.m1, bres.incr1, bres.incr2) |
#define | SLLSPERBLOCK 25 |
#define | NUMPTSTOBUFFER 200 |
#define | EVALUATEEDGEWINDING(pAET, pPrevAET, y, fixWAET) |
#define | EVALUATEEDGEEVENODD(pAET, pPrevAET, y) |
#define | MAXINT 0x7fffffff |
#define | MININT -MAXINT |
'typedefs' |
typedef struct _EdgeTableEntry | EdgeTableEntry |
typedef struct _ScanLineList | ScanLineList |
typedef struct _ScanLineListBlock | ScanLineListBlock |
typedef struct DDXPointRec * | DDXPointPtr |
Documentación de los 'defines'
#define BRESINCRPGON |
( |
|
d, |
|
|
|
minval, |
|
|
|
m, |
|
|
|
m1, |
|
|
|
incr1, |
|
|
|
incr2 |
|
) |
| |
Valor:{ \
if (m1 > 0) { \
if (d > 0) { \
minval += m1; \
d += incr1; \
} \
else { \
minval += m; \
d += incr2; \
} \
} else {\
if (d >= 0) { \
minval += m1; \
d += incr1; \
} \
else { \
minval += m; \
d += incr2; \
} \
} \
}
#define BRESINCRPGONSTRUCT |
( |
|
bres | ) |
BRESINCRPGON(bres.d, bres.minor, bres.m, bres.m1, bres.incr1, bres.incr2) |
#define BRESINITPGON |
( |
|
dy, |
|
|
|
x1, |
|
|
|
x2, |
|
|
|
xStart, |
|
|
|
d, |
|
|
|
m, |
|
|
|
m1, |
|
|
|
incr1, |
|
|
|
incr2 |
|
) |
| |
Valor:{ \
int dx; \
\
\
if ((dy) != 0) { \
xStart = (x1); \
dx = (x2) - xStart; \
if (dx < 0) { \
m = dx / (dy); \
m1 = m - 1; \
incr1 = -2 * dx + 2 * (dy) * m1; \
incr2 = -2 * dx + 2 * (dy) * m; \
d = 2 * m * (dy) - 2 * dx - 2 * (dy); \
} else { \
m = dx / (dy); \
m1 = m + 1; \
incr1 = 2 * dx - 2 * (dy) * m1; \
incr2 = 2 * dx - 2 * (dy) * m; \
d = -2 * m * (dy) + 2 * dx; \
} \
} \
}
#define BRESINITPGONSTRUCT |
( |
|
dmaj, |
|
|
|
min1, |
|
|
|
min2, |
|
|
|
bres |
|
) |
| |
Valor:BRESINITPGON(dmaj, min1, min2, bres.minor, bres.d, \
bres.m, bres.m1, bres.incr1, bres.incr2)
#define EVALUATEEDGEEVENODD |
( |
|
pAET, |
|
|
|
pPrevAET, |
|
|
|
y |
|
) |
| |
Valor:{ \
if (pAET->ymax == y) { \
pPrevAET->next = pAET->next; \
pAET = pPrevAET->next; \
if (pAET) \
pAET->back = pPrevAET; \
} \
else { \
BRESINCRPGONSTRUCT(pAET->bres) \
pPrevAET = pAET; \
pAET = pAET->next; \
} \
}
#define EVALUATEEDGEWINDING |
( |
|
pAET, |
|
|
|
pPrevAET, |
|
|
|
y, |
|
|
|
fixWAET |
|
) |
| |
Valor:{ \
if (pAET->ymax == y) { \
pPrevAET->next = pAET->next; \
pAET = pPrevAET->next; \
fixWAET = 1; \
if (pAET) \
pAET->back = pPrevAET; \
} \
else { \
BRESINCRPGONSTRUCT(pAET->bres); \
pPrevAET = pAET; \
pAET = pAET->next; \
} \
}
#define MAXINT 0x7fffffff |
#define NUMPTSTOBUFFER 200 |
Documentación de los 'typedefs'