shithub: tinygl

ref: 2bbacdba0601b00ea3c919111dbe6e587fb7c55b
dir: /src/zline.h/

View raw version
{
    int n, dx, dy, sx, pp_inc_1, pp_inc_2;
    register int a;
    register PIXEL *pp;
#if defined(INTERP_RGB) || TGL_FEATURE_RENDER_BITS == 24
    register unsigned int r, g, b;
#endif
#ifdef INTERP_RGB
    register unsigned int rinc, ginc, binc;
#endif
#ifdef INTERP_Z
    register unsigned short *pz;
    int zinc;
    register int z, zz;
#endif

    if (p1->y > p2->y || (p1->y == p2->y && p1->x > p2->x)) {
	ZBufferPoint *tmp;
	tmp = p1;
	p1 = p2;
	p2 = tmp;
    }
    sx = zb->xsize;
    pp = (PIXEL *) ((char *) zb->pbuf + zb->linesize * p1->y + p1->x * PSZB);
#ifdef INTERP_Z
    pz = zb->zbuf + (p1->y * sx + p1->x);
    z = p1->z;
#endif

    dx = p2->x - p1->x;
    dy = p2->y - p1->y;
#ifdef INTERP_RGB
    r = p2->r << 8;
    g = p2->g << 8;
    b = p2->b << 8;
#elif TGL_FEATURE_RENDER_BITS == 24
    /* for 24 bits, we store the colors in different variables */
    r = p2->r >> 8;
    g = p2->g >> 8;
    b = p2->b >> 8;
#endif

#ifdef INTERP_RGB
#define RGB(x) x
#if TGL_FEATURE_RENDER_BITS == 24
#define RGBPIXEL pp[0] = r >> 16, pp[1] = g >> 16, pp[2] = b >> 16
#else
#define RGBPIXEL *pp = RGB_TO_PIXEL(r >> 8,g >> 8,b >> 8)
#endif
#else /* INTERP_RGB */
#define RGB(x)
#if TGL_FEATURE_RENDER_BITS == 24
#define RGBPIXEL pp[0] = r, pp[1] = g, pp[2] = b
#else
#define RGBPIXEL *pp = color
#endif
#endif /* INTERP_RGB */

#ifdef INTERP_Z
#define ZZ(x) x
#define PUTPIXEL() 				\
  {						\
    zz=z >> ZB_POINT_Z_FRAC_BITS;		\
    if (ZCMP(zz,*pz))  { 			\
      RGBPIXEL;	\
      *pz=zz; 					\
    }						\
  }
#else /* INTERP_Z */
#define ZZ(x)
#define PUTPIXEL() RGBPIXEL
#endif /* INTERP_Z */

#define DRAWLINE(dx,dy,inc_1,inc_2) \
    n=dx;\
    ZZ(zinc=(p2->z-p1->z)/n);\
    RGB(rinc=((p2->r-p1->r) << 8)/n;\
        ginc=((p2->g-p1->g) << 8)/n;\
        binc=((p2->b-p1->b) << 8)/n);\
    a=2*dy-dx;\
    dy=2*dy;\
    dx=2*dx-dy;\
    pp_inc_1 = (inc_1) * PSZB;\
    pp_inc_2 = (inc_2) * PSZB;\
    do {\
        PUTPIXEL();\
        ZZ(z+=zinc);\
        RGB(r+=rinc;g+=ginc;b+=binc);\
        if (a>0) { pp=(PIXEL *)((char *)pp + pp_inc_1); ZZ(pz+=(inc_1));  a-=dx; }\
	else { pp=(PIXEL *)((char *)pp + pp_inc_2); ZZ(pz+=(inc_2)); a+=dy; }\
    } while (--n >= 0);

/* fin macro */

    if (dx == 0 && dy == 0) {
	PUTPIXEL();
    } else if (dx > 0) {
	if (dx >= dy) {
	    DRAWLINE(dx, dy, sx + 1, 1);
	} else {
	    DRAWLINE(dy, dx, sx + 1, sx);
	}
    } else {
	dx = -dx;
	if (dx >= dy) {
	    DRAWLINE(dx, dy, sx - 1, -1);
	} else {
	    DRAWLINE(dy, dx, sx - 1, sx);
	}
    }
}

#undef INTERP_Z
#undef INTERP_RGB

/* internal defines */
#undef DRAWLINE
#undef PUTPIXEL
#undef ZZ
#undef RGB
#undef RGBPIXEL