dos3d

diff src/scantmpl.h @ 3:0e781cc43178

adding textures
author John Tsiombikas <nuclear@member.fsf.org>
date Mon, 21 Nov 2011 10:16:09 +0200
parents f04884489bad
children bce78aaafc68
line diff
     1.1 --- a/src/scantmpl.h	Mon Nov 21 10:15:37 2011 +0200
     1.2 +++ b/src/scantmpl.h	Mon Nov 21 10:16:09 2011 +0200
     1.3 @@ -25,7 +25,10 @@
     1.4  #ifdef INTERP_ENERGY
     1.5  	float e, de, dfde;
     1.6  #endif
     1.7 -	float x, y;
     1.8 +#ifdef INTERP_TEX
     1.9 +	float u, v, du, dv, dfdu, dfdv;
    1.10 +#endif
    1.11 +	float x;
    1.12  	struct vertex *edge;
    1.13  
    1.14  	dy = v1->pos.y - v0->pos.y;
    1.15 @@ -37,7 +40,6 @@
    1.16  	dfdx = dx / dy;
    1.17  
    1.18  #ifdef INTERP_DEPTH
    1.19 -	assert(fb->zbuf);
    1.20  	dz = v1->pos.z - v0->pos.z;
    1.21  	dfdz = dz / dy;
    1.22  #endif
    1.23 @@ -45,6 +47,12 @@
    1.24  	de = v1->energy - v0->energy;
    1.25  	dfde = de / dy;
    1.26  #endif
    1.27 +#ifdef INTERP_TEX
    1.28 +	du = v1->tc.x - v0->tc.x;
    1.29 +	dv = v1->tc.y - v0->tc.y;
    1.30 +	dfdu = du / dy;
    1.31 +	dfdv = dv / dy;
    1.32 +#endif
    1.33  
    1.34  	if(dy < 0.0) {
    1.35  		struct vertex *tmp = v0;
    1.36 @@ -65,6 +73,10 @@
    1.37  #ifdef INTERP_ENERGY
    1.38  	e = v0->energy;
    1.39  #endif
    1.40 +#ifdef INTERP_TEX
    1.41 +	u = v0->tc.x;
    1.42 +	v = v0->tc.y;
    1.43 +#endif
    1.44  	for(i=start; i<end; i++) {
    1.45  		edge[i].pos.x = x;
    1.46  		x += dfdx;
    1.47 @@ -81,13 +93,21 @@
    1.48  #else
    1.49  		edge[i].energy = v0->energy;
    1.50  #endif
    1.51 +
    1.52 +#ifdef INTERP_TEX
    1.53 +		edge[i].tc.x = u;
    1.54 +		edge[i].tc.y = v;
    1.55 +		u += dfdu;
    1.56 +		v += dfdv;
    1.57 +#endif
    1.58  	}
    1.59  }
    1.60  
    1.61  static void SCAN_LINE(int y, unsigned char *sline)
    1.62  {
    1.63 -	int i, x0, x1, len, tmp, cidx;
    1.64 -#if defined(INTERP_DEPTH) || defined(INTERP_ENERGY)
    1.65 +	int x0, x1, len, tmp, cidx;
    1.66 +#if defined(INTERP_DEPTH) || defined(INTERP_ENERGY) || defined(INTERP_TEX)
    1.67 +	int i;
    1.68  	float x, dx;
    1.69  #endif
    1.70  #ifdef INTERP_DEPTH
    1.71 @@ -96,6 +116,10 @@
    1.72  #ifdef INTERP_ENERGY
    1.73  	float e, de, dfde;
    1.74  #endif
    1.75 +#ifdef INTERP_TEX
    1.76 +	int tx, ty;
    1.77 +	float u, v, du, dv, dfdu, dfdv;
    1.78 +#endif
    1.79  	struct vertex *left, *right;
    1.80  
    1.81  	x0 = (int)ROUND(vleft[y].pos.x);
    1.82 @@ -124,7 +148,7 @@
    1.83  	assert(len >= 0);
    1.84  
    1.85  	cidx = left[y].cidx;
    1.86 -#if !defined(INTERP_DEPTH) && !defined(INTERP_ENERGY)
    1.87 +#if !defined(INTERP_DEPTH) && !defined(INTERP_ENERGY) && !defined(INTERP_TEX)
    1.88  	/* no interpolation at all, just memset the whole scanline */
    1.89  	memset(sline + x0, cidx + left[y].energy * st->col_range, len);
    1.90  #else
    1.91 @@ -146,13 +170,36 @@
    1.92  	de = right[y].energy - e;
    1.93  	dfde = de / dx;
    1.94  #endif
    1.95 +#ifdef INTERP_TEX
    1.96 +	u = left[y].tc.x;
    1.97 +	v = left[y].tc.y;
    1.98 +	du = right[y].tc.x - u;
    1.99 +	dv = right[y].tc.y - v;
   1.100 +	dfdu = du / dx;
   1.101 +	dfdv = dv / dx;
   1.102 +#endif
   1.103  
   1.104  	for(i=0; i<len; i++) {
   1.105 +		int c = cidx;
   1.106 +
   1.107 +#ifdef INTERP_DEPTH
   1.108 +		z += dfdz;
   1.109 +#endif
   1.110 +#ifdef INTERP_TEX
   1.111 +		tx = (int)(u * st->tex.width) & st->tex.xmask;
   1.112 +		ty = (int)(v * st->tex.height) & st->tex.ymask;
   1.113 +		c = st->tex.pixels[(ty << st->tex.xshift) + tx];
   1.114 +
   1.115 +		u += dfdu;
   1.116 +		v += dfdv;
   1.117 +#endif
   1.118  #ifdef INTERP_ENERGY
   1.119 -		cidx = left[y].cidx + e * st->col_range;
   1.120 +		c += e * st->col_range;
   1.121  		e += dfde;
   1.122 +#else
   1.123 +		c += left[y].energy * st->col_range;
   1.124  #endif
   1.125 -		sline[x0 + i] = cidx;
   1.126 +		sline[x0 + i] = c;
   1.127  	}
   1.128  #endif	/* flat */
   1.129  }