de51889f62
git-svn-id: https://svn.code.sf.net/p/fteqw/code/trunk@143 fc73d0e0-1445-4013-8a0c-d673dee63da5
146 lines
4 KiB
C
146 lines
4 KiB
C
/*
|
|
Copyright (C) 1996-1997 Id Software, Inc.
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License
|
|
as published by the Free Software Foundation; either version 2
|
|
of the License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
// d_local.h: private rasterization driver defs
|
|
|
|
#include "r_shared.h"
|
|
|
|
//
|
|
// TODO: fine-tune this; it's based on providing some overage even if there
|
|
// is a 2k-wide scan, with subdivision every 8, for 256 spans of 12 bytes each
|
|
//
|
|
#define SCANBUFFERPAD 0x1000
|
|
|
|
#define R_SKY_SMASK 0x007F0000
|
|
#define R_SKY_TMASK 0x007F0000
|
|
|
|
#define DS_SPAN_LIST_END -128
|
|
|
|
#define SURFCACHE_SIZE_AT_320X200 600*1024
|
|
|
|
typedef struct surfcache_s
|
|
{
|
|
struct surfcache_s *next;
|
|
struct surfcache_s **owner; // NULL is an empty chunk of memory
|
|
int lightadj[MAXLIGHTMAPS]; // checked for strobe flush
|
|
int dlight;
|
|
int size; // including header
|
|
unsigned width;
|
|
unsigned height; // DEBUG only needed for debug
|
|
float mipscale;
|
|
struct texture_s *texture; // checked for animating textures
|
|
int bytesperpix;
|
|
int fcache;
|
|
qbyte data[4]; // width*height elements
|
|
} surfcache_t;
|
|
|
|
// !!! if this is changed, it must be changed in asm_draw.h too !!!
|
|
typedef struct sspan_s
|
|
{
|
|
int u, v, count;
|
|
} sspan_t;
|
|
|
|
extern cvar_t d_subdiv16;
|
|
|
|
extern float scale_for_mip;
|
|
|
|
extern qboolean d_roverwrapped;
|
|
extern surfcache_t *sc_rover;
|
|
extern surfcache_t *d_initial_rover;
|
|
|
|
extern float d_sdivzstepu, d_tdivzstepu, d_zistepu;
|
|
extern float d_sdivzstepv, d_tdivzstepv, d_zistepv;
|
|
extern float d_sdivzorigin, d_tdivzorigin, d_ziorigin;
|
|
|
|
fixed16_t sadjust, tadjust;
|
|
fixed16_t bbextents, bbextentt;
|
|
|
|
|
|
void D_DrawSpans8_Smooth (espan_t *pspan);
|
|
void D_DrawSpans8 (espan_t *pspans);
|
|
void D_DrawSpans16 (espan_t *pspans);
|
|
void D_DrawSpans8SubDiv16 (espan_t *pspans);
|
|
void D_DrawSpans16From8 (espan_t *pspan); //skybox in 16 bit renderer (fixme - load tgas with more colourdepth).
|
|
void D_DrawZSpans (espan_t *pspans);
|
|
void Turbulent8 (espan_t *pspan);
|
|
void Turbulent16 (espan_t *pspan);
|
|
void Turbulent32 (espan_t *pspan);
|
|
void D_SpriteDrawSpans (sspan_t *pspan);
|
|
|
|
void D_DrawSkyScans8 (espan_t *pspan);
|
|
void D_DrawSkyScans16 (espan_t *pspan);
|
|
void D_DrawSkyScans32 (espan_t *pspan);
|
|
|
|
void R_ShowSubDiv (void);
|
|
void (*prealspandrawer)(void);
|
|
surfcache_t *D_CacheSurface (msurface_t *surface, int miplevel);
|
|
|
|
extern int D_MipLevelForScale (float scale);
|
|
|
|
#if id386
|
|
extern void D_PolysetAff8Start (void);
|
|
extern void D_PolysetAff8End (void);
|
|
#endif
|
|
|
|
extern short *d_pzbuffer;
|
|
extern unsigned int d_zrowbytes, d_zwidth;
|
|
|
|
extern int *d_pscantable;
|
|
extern int d_scantable[MAXHEIGHT];
|
|
|
|
extern int d_vrectx, d_vrecty, d_vrectright_particle, d_vrectbottom_particle;
|
|
|
|
extern int d_y_aspect_shift, d_pix_min, d_pix_max, d_pix_shift;
|
|
|
|
extern pixel_t *d_viewbuffer;
|
|
|
|
extern short *zspantable[MAXHEIGHT];
|
|
|
|
extern int d_minmip;
|
|
extern float d_scalemip[3];
|
|
|
|
extern void (*d_drawspans) (espan_t *pspan);
|
|
|
|
|
|
|
|
#ifdef PEXT_TRANS
|
|
typedef qbyte tlookup[256][256];
|
|
typedef qbyte tlookupp[256];
|
|
extern tlookup *t_lookup;
|
|
extern tlookupp *t_curlookupp;
|
|
extern int t_numtables;
|
|
extern int t_numtablesinv;//65546/numtables
|
|
extern int t_state;
|
|
|
|
#define TT_REVERSE 0x1 // reverse table points
|
|
#define TT_ZERO 0x2 // zero alpha
|
|
#define TT_ONE 0x4 // full alpha
|
|
#define TT_USEHALF 0x8 // using half transtables
|
|
|
|
// cvar defines for transtable
|
|
extern cvar_t r_transtablewrite;
|
|
extern cvar_t r_transtables;
|
|
extern cvar_t r_transtablefull;
|
|
|
|
void D_InitTrans(void);
|
|
#define Trans(p, p2) (t_curlookupp[p][p2])
|
|
// void Set_TransLevelI(int level);
|
|
void Set_TransLevelF(float level);
|
|
#endif
|
|
|