123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769 |
- #include "quakedef.h"
- #include "r_local.h"
- #include "d_local.h"
-
- #define LIGHT_MIN 5
-
- mtriangle_t *ptriangles;
- affinetridesc_t r_affinetridesc;
- void * acolormap;
- trivertx_t *r_apverts;
- mdl_t *pmdl;
- vec3_t r_plightvec;
- int r_ambientlight;
- float r_shadelight;
- aliashdr_t *paliashdr;
- finalvert_t *pfinalverts;
- auxvert_t *pauxverts;
- static float ziscale;
- static model_t *pmodel;
- static vec3_t alias_forward, alias_right, alias_up;
- static maliasskindesc_t *pskindesc;
- int r_amodels_drawn;
- int a_skinwidth;
- int r_anumverts;
- float aliastransform[3][4];
- typedef struct {
- int index0;
- int index1;
- } aedge_t;
- static aedge_t aedges[12] = {
- {0, 1}, {1, 2}, {2, 3}, {3, 0},
- {4, 5}, {5, 6}, {6, 7}, {7, 4},
- {0, 5}, {1, 4}, {2, 7}, {3, 6}
- };
- #define NUMVERTEXNORMALS 162
- float r_avertexnormals[NUMVERTEXNORMALS][3] = {
- #include "anorms.h"
- };
- void R_AliasTransformAndProjectFinalVerts (finalvert_t *fv,
- stvert_t *pstverts);
- void R_AliasSetUpTransform (int trivial_accept);
- void R_AliasTransformVector (vec3_t in, vec3_t out);
- void R_AliasTransformFinalVert (finalvert_t *fv, auxvert_t *av,
- trivertx_t *pverts, stvert_t *pstverts);
- void R_AliasProjectFinalVert (finalvert_t *fv, auxvert_t *av);
- qboolean R_AliasCheckBBox (void)
- {
- int i, flags, frame, numv;
- aliashdr_t *pahdr;
- float zi, basepts[8][3], v0, v1, frac;
- finalvert_t *pv0, *pv1, viewpts[16];
- auxvert_t *pa0, *pa1, viewaux[16];
- maliasframedesc_t *pframedesc;
- qboolean zclipped, zfullyclipped;
- unsigned anyclip, allclip;
- int minz;
-
- currententity->trivial_accept = 0;
- pmodel = currententity->model;
- pahdr = Mod_Extradata (pmodel);
- pmdl = (mdl_t *)((byte *)pahdr + pahdr->model);
- R_AliasSetUpTransform (0);
- frame = currententity->frame;
- if ((frame >= pmdl->numframes) || (frame < 0))
- {
- Con_DPrintf ("No such frame %d %s\n", frame,
- pmodel->name);
- frame = 0;
- }
- pframedesc = &pahdr->frames[frame];
- basepts[0][0] = basepts[1][0] = basepts[2][0] = basepts[3][0] =
- (float)pframedesc->bboxmin.v[0];
- basepts[4][0] = basepts[5][0] = basepts[6][0] = basepts[7][0] =
- (float)pframedesc->bboxmax.v[0];
- basepts[0][1] = basepts[3][1] = basepts[5][1] = basepts[6][1] =
- (float)pframedesc->bboxmin.v[1];
- basepts[1][1] = basepts[2][1] = basepts[4][1] = basepts[7][1] =
- (float)pframedesc->bboxmax.v[1];
- basepts[0][2] = basepts[1][2] = basepts[4][2] = basepts[5][2] =
- (float)pframedesc->bboxmin.v[2];
- basepts[2][2] = basepts[3][2] = basepts[6][2] = basepts[7][2] =
- (float)pframedesc->bboxmax.v[2];
- zclipped = false;
- zfullyclipped = true;
- minz = 9999;
- for (i=0; i<8 ; i++)
- {
- R_AliasTransformVector (&basepts[i][0], &viewaux[i].fv[0]);
- if (viewaux[i].fv[2] < ALIAS_Z_CLIP_PLANE)
- {
-
- viewpts[i].flags = ALIAS_Z_CLIP;
- zclipped = true;
- }
- else
- {
- if (viewaux[i].fv[2] < minz)
- minz = viewaux[i].fv[2];
- viewpts[i].flags = 0;
- zfullyclipped = false;
- }
- }
-
- if (zfullyclipped)
- {
- return false;
- }
- numv = 8;
- if (zclipped)
- {
-
-
- for (i=0 ; i<12 ; i++)
- {
-
- pv0 = &viewpts[aedges[i].index0];
- pv1 = &viewpts[aedges[i].index1];
- pa0 = &viewaux[aedges[i].index0];
- pa1 = &viewaux[aedges[i].index1];
-
- if (pv0->flags ^ pv1->flags)
- {
- frac = (ALIAS_Z_CLIP_PLANE - pa0->fv[2]) /
- (pa1->fv[2] - pa0->fv[2]);
- viewaux[numv].fv[0] = pa0->fv[0] +
- (pa1->fv[0] - pa0->fv[0]) * frac;
- viewaux[numv].fv[1] = pa0->fv[1] +
- (pa1->fv[1] - pa0->fv[1]) * frac;
- viewaux[numv].fv[2] = ALIAS_Z_CLIP_PLANE;
- viewpts[numv].flags = 0;
- numv++;
- }
- }
- }
- anyclip = 0;
- allclip = ALIAS_XY_CLIP_MASK;
- for (i=0 ; i<numv ; i++)
- {
-
- if (viewpts[i].flags & ALIAS_Z_CLIP)
- continue;
- zi = 1.0 / viewaux[i].fv[2];
-
- v0 = (viewaux[i].fv[0] * xscale * zi) + xcenter;
- v1 = (viewaux[i].fv[1] * yscale * zi) + ycenter;
- flags = 0;
- if (v0 < r_refdef.fvrectx)
- flags |= ALIAS_LEFT_CLIP;
- if (v1 < r_refdef.fvrecty)
- flags |= ALIAS_TOP_CLIP;
- if (v0 > r_refdef.fvrectright)
- flags |= ALIAS_RIGHT_CLIP;
- if (v1 > r_refdef.fvrectbottom)
- flags |= ALIAS_BOTTOM_CLIP;
- anyclip |= flags;
- allclip &= flags;
- }
- if (allclip)
- return false;
- currententity->trivial_accept = !anyclip & !zclipped;
- if (currententity->trivial_accept)
- {
- if (minz > (r_aliastransition + (pmdl->size * r_resfudge)))
- {
- currententity->trivial_accept |= 2;
- }
- }
- return true;
- }
- void R_AliasTransformVector (vec3_t in, vec3_t out)
- {
- out[0] = DotProduct(in, aliastransform[0]) + aliastransform[0][3];
- out[1] = DotProduct(in, aliastransform[1]) + aliastransform[1][3];
- out[2] = DotProduct(in, aliastransform[2]) + aliastransform[2][3];
- }
- void R_AliasPreparePoints (void)
- {
- int i;
- stvert_t *pstverts;
- finalvert_t *fv;
- auxvert_t *av;
- mtriangle_t *ptri;
- finalvert_t *pfv[3];
- pstverts = (stvert_t *)((byte *)paliashdr + paliashdr->stverts);
- r_anumverts = pmdl->numverts;
- fv = pfinalverts;
- av = pauxverts;
- for (i=0 ; i<r_anumverts ; i++, fv++, av++, r_apverts++, pstverts++)
- {
- R_AliasTransformFinalVert (fv, av, r_apverts, pstverts);
- if (av->fv[2] < ALIAS_Z_CLIP_PLANE)
- fv->flags |= ALIAS_Z_CLIP;
- else
- {
- R_AliasProjectFinalVert (fv, av);
- if (fv->v[0] < r_refdef.aliasvrect.x)
- fv->flags |= ALIAS_LEFT_CLIP;
- if (fv->v[1] < r_refdef.aliasvrect.y)
- fv->flags |= ALIAS_TOP_CLIP;
- if (fv->v[0] > r_refdef.aliasvrectright)
- fv->flags |= ALIAS_RIGHT_CLIP;
- if (fv->v[1] > r_refdef.aliasvrectbottom)
- fv->flags |= ALIAS_BOTTOM_CLIP;
- }
- }
- r_affinetridesc.numtriangles = 1;
- ptri = (mtriangle_t *)((byte *)paliashdr + paliashdr->triangles);
- for (i=0 ; i<pmdl->numtris ; i++, ptri++)
- {
- pfv[0] = &pfinalverts[ptri->vertindex[0]];
- pfv[1] = &pfinalverts[ptri->vertindex[1]];
- pfv[2] = &pfinalverts[ptri->vertindex[2]];
- if ( pfv[0]->flags & pfv[1]->flags & pfv[2]->flags & (ALIAS_XY_CLIP_MASK | ALIAS_Z_CLIP) )
- continue;
-
- if ( ! ( (pfv[0]->flags | pfv[1]->flags | pfv[2]->flags) &
- (ALIAS_XY_CLIP_MASK | ALIAS_Z_CLIP) ) )
- {
- r_affinetridesc.pfinalverts = pfinalverts;
- r_affinetridesc.ptriangles = ptri;
- D_PolysetDraw ();
- }
- else
- {
- R_AliasClipTriangle (ptri);
- }
- }
- }
- void R_AliasSetUpTransform (int trivial_accept)
- {
- int i;
- float rotationmatrix[3][4], t2matrix[3][4];
- static float tmatrix[3][4];
- static float viewmatrix[3][4];
- vec3_t angles;
- angles[ROLL] = currententity->angles[ROLL];
- angles[PITCH] = -currententity->angles[PITCH];
- angles[YAW] = currententity->angles[YAW];
- AngleVectors (angles, alias_forward, alias_right, alias_up);
- tmatrix[0][0] = pmdl->scale[0];
- tmatrix[1][1] = pmdl->scale[1];
- tmatrix[2][2] = pmdl->scale[2];
- tmatrix[0][3] = pmdl->scale_origin[0];
- tmatrix[1][3] = pmdl->scale_origin[1];
- tmatrix[2][3] = pmdl->scale_origin[2];
- for (i=0 ; i<3 ; i++)
- {
- t2matrix[i][0] = alias_forward[i];
- t2matrix[i][1] = -alias_right[i];
- t2matrix[i][2] = alias_up[i];
- }
- t2matrix[0][3] = -modelorg[0];
- t2matrix[1][3] = -modelorg[1];
- t2matrix[2][3] = -modelorg[2];
- R_ConcatTransforms (t2matrix, tmatrix, rotationmatrix);
- VectorCopy (vright, viewmatrix[0]);
- VectorCopy (vup, viewmatrix[1]);
- VectorInverse (viewmatrix[1]);
- VectorCopy (vpn, viewmatrix[2]);
- R_ConcatTransforms (viewmatrix, rotationmatrix, aliastransform);
- if (trivial_accept)
- {
- for (i=0 ; i<4 ; i++)
- {
- aliastransform[0][i] *= aliasxscale *
- (1.0 / ((float)0x8000 * 0x10000));
- aliastransform[1][i] *= aliasyscale *
- (1.0 / ((float)0x8000 * 0x10000));
- aliastransform[2][i] *= 1.0 / ((float)0x8000 * 0x10000);
- }
- }
- }
- void R_AliasTransformFinalVert (finalvert_t *fv, auxvert_t *av,
- trivertx_t *pverts, stvert_t *pstverts)
- {
- int temp;
- float lightcos, *plightnormal;
- av->fv[0] = DotProduct(pverts->v, aliastransform[0]) +
- aliastransform[0][3];
- av->fv[1] = DotProduct(pverts->v, aliastransform[1]) +
- aliastransform[1][3];
- av->fv[2] = DotProduct(pverts->v, aliastransform[2]) +
- aliastransform[2][3];
- fv->v[2] = pstverts->s;
- fv->v[3] = pstverts->t;
- fv->flags = pstverts->onseam;
- plightnormal = r_avertexnormals[pverts->lightnormalindex];
- lightcos = DotProduct (plightnormal, r_plightvec);
- temp = r_ambientlight;
- if (lightcos < 0)
- {
- temp += (int)(r_shadelight * lightcos);
-
-
- if (temp < 0)
- temp = 0;
- }
- fv->v[4] = temp;
- }
- #if !id386
- void R_AliasTransformAndProjectFinalVerts (finalvert_t *fv, stvert_t *pstverts)
- {
- int i, temp;
- float lightcos, *plightnormal, zi;
- trivertx_t *pverts;
- pverts = r_apverts;
- for (i=0 ; i<r_anumverts ; i++, fv++, pverts++, pstverts++)
- {
-
- zi = 1.0 / (DotProduct(pverts->v, aliastransform[2]) +
- aliastransform[2][3]);
-
-
-
- fv->v[5] = zi;
- fv->v[0] = ((DotProduct(pverts->v, aliastransform[0]) +
- aliastransform[0][3]) * zi) + aliasxcenter;
- fv->v[1] = ((DotProduct(pverts->v, aliastransform[1]) +
- aliastransform[1][3]) * zi) + aliasycenter;
- fv->v[2] = pstverts->s;
- fv->v[3] = pstverts->t;
- fv->flags = pstverts->onseam;
-
- plightnormal = r_avertexnormals[pverts->lightnormalindex];
- lightcos = DotProduct (plightnormal, r_plightvec);
- temp = r_ambientlight;
- if (lightcos < 0)
- {
- temp += (int)(r_shadelight * lightcos);
-
-
- if (temp < 0)
- temp = 0;
- }
- fv->v[4] = temp;
- }
- }
- #endif
- void R_AliasProjectFinalVert (finalvert_t *fv, auxvert_t *av)
- {
- float zi;
- zi = 1.0 / av->fv[2];
- fv->v[5] = zi * ziscale;
- fv->v[0] = (av->fv[0] * aliasxscale * zi) + aliasxcenter;
- fv->v[1] = (av->fv[1] * aliasyscale * zi) + aliasycenter;
- }
- void R_AliasPrepareUnclippedPoints (void)
- {
- stvert_t *pstverts;
- finalvert_t *fv;
- pstverts = (stvert_t *)((byte *)paliashdr + paliashdr->stverts);
- r_anumverts = pmdl->numverts;
- fv = pfinalverts;
- R_AliasTransformAndProjectFinalVerts (fv, pstverts);
- if (r_affinetridesc.drawtype)
- D_PolysetDrawFinalVerts (fv, r_anumverts);
- r_affinetridesc.pfinalverts = pfinalverts;
- r_affinetridesc.ptriangles = (mtriangle_t *)
- ((byte *)paliashdr + paliashdr->triangles);
- r_affinetridesc.numtriangles = pmdl->numtris;
- D_PolysetDraw ();
- }
- void R_AliasSetupSkin (void)
- {
- int skinnum;
- int i, numskins;
- maliasskingroup_t *paliasskingroup;
- float *pskinintervals, fullskininterval;
- float skintargettime, skintime;
- skinnum = currententity->skinnum;
- if ((skinnum >= pmdl->numskins) || (skinnum < 0))
- {
- Con_DPrintf ("R_AliasSetupSkin: no such skin # %d\n", skinnum);
- skinnum = 0;
- }
- pskindesc = ((maliasskindesc_t *)
- ((byte *)paliashdr + paliashdr->skindesc)) + skinnum;
- a_skinwidth = pmdl->skinwidth;
- if (pskindesc->type == ALIAS_SKIN_GROUP)
- {
- paliasskingroup = (maliasskingroup_t *)((byte *)paliashdr +
- pskindesc->skin);
- pskinintervals = (float *)
- ((byte *)paliashdr + paliasskingroup->intervals);
- numskins = paliasskingroup->numskins;
- fullskininterval = pskinintervals[numskins-1];
-
- skintime = cl.time + currententity->syncbase;
-
-
-
- skintargettime = skintime -
- ((int)(skintime / fullskininterval)) * fullskininterval;
-
- for (i=0 ; i<(numskins-1) ; i++)
- {
- if (pskinintervals[i] > skintargettime)
- break;
- }
-
- pskindesc = &paliasskingroup->skindescs[i];
- }
- r_affinetridesc.pskindesc = pskindesc;
- r_affinetridesc.pskin = (void *)((byte *)paliashdr + pskindesc->skin);
- r_affinetridesc.skinwidth = a_skinwidth;
- r_affinetridesc.seamfixupX16 = (a_skinwidth >> 1) << 16;
- r_affinetridesc.skinheight = pmdl->skinheight;
- if (currententity->scoreboard)
- {
- byte *base;
- if (!currententity->scoreboard->skin)
- Skin_Find (currententity->scoreboard);
- base = Skin_Cache (currententity->scoreboard->skin);
- if (base)
- {
- r_affinetridesc.pskin = base;
- r_affinetridesc.skinwidth = 320;
- r_affinetridesc.skinheight = 200;
- }
- }
- }
- void R_AliasSetupLighting (alight_t *plighting)
- {
- r_ambientlight = plighting->ambientlight;
- if (r_ambientlight < LIGHT_MIN)
- r_ambientlight = LIGHT_MIN;
- r_ambientlight = (255 - r_ambientlight) << VID_CBITS;
- if (r_ambientlight < LIGHT_MIN)
- r_ambientlight = LIGHT_MIN;
- r_shadelight = plighting->shadelight;
- if (r_shadelight < 0)
- r_shadelight = 0;
- r_shadelight *= VID_GRADES;
- r_plightvec[0] = DotProduct (plighting->plightvec, alias_forward);
- r_plightvec[1] = -DotProduct (plighting->plightvec, alias_right);
- r_plightvec[2] = DotProduct (plighting->plightvec, alias_up);
- }
- void R_AliasSetupFrame (void)
- {
- int frame;
- int i, numframes;
- maliasgroup_t *paliasgroup;
- float *pintervals, fullinterval, targettime, time;
- frame = currententity->frame;
- if ((frame >= pmdl->numframes) || (frame < 0))
- {
- Con_DPrintf ("R_AliasSetupFrame: no such frame %d\n", frame);
- frame = 0;
- }
- if (paliashdr->frames[frame].type == ALIAS_SINGLE)
- {
- r_apverts = (trivertx_t *)
- ((byte *)paliashdr + paliashdr->frames[frame].frame);
- return;
- }
-
- paliasgroup = (maliasgroup_t *)
- ((byte *)paliashdr + paliashdr->frames[frame].frame);
- pintervals = (float *)((byte *)paliashdr + paliasgroup->intervals);
- numframes = paliasgroup->numframes;
- fullinterval = pintervals[numframes-1];
- time = cl.time + currententity->syncbase;
- targettime = time - ((int)(time / fullinterval)) * fullinterval;
- for (i=0 ; i<(numframes-1) ; i++)
- {
- if (pintervals[i] > targettime)
- break;
- }
- r_apverts = (trivertx_t *)
- ((byte *)paliashdr + paliasgroup->frames[i].frame);
- }
- void R_AliasDrawModel (alight_t *plighting)
- {
- finalvert_t finalverts[MAXALIASVERTS +
- ((CACHE_SIZE - 1) / sizeof(finalvert_t)) + 1];
- auxvert_t auxverts[MAXALIASVERTS];
- r_amodels_drawn++;
- pfinalverts = (finalvert_t *)
- (((long)&finalverts[0] + CACHE_SIZE - 1) & ~(CACHE_SIZE - 1));
- pauxverts = &auxverts[0];
- paliashdr = (aliashdr_t *)Mod_Extradata (currententity->model);
- pmdl = (mdl_t *)((byte *)paliashdr + paliashdr->model);
- R_AliasSetupSkin ();
- R_AliasSetUpTransform (currententity->trivial_accept);
- R_AliasSetupLighting (plighting);
- R_AliasSetupFrame ();
- if (!currententity->colormap)
- Sys_Error ("R_AliasDrawModel: !currententity->colormap");
- r_affinetridesc.drawtype = (currententity->trivial_accept == 3) &&
- r_recursiveaffinetriangles;
- if (r_affinetridesc.drawtype)
- {
- D_PolysetUpdateTables ();
- }
- else
- {
- #if id386
- D_Aff8Patch (currententity->colormap);
- #endif
- }
- acolormap = currententity->colormap;
- if (currententity != &cl.viewent)
- ziscale = (float)0x8000 * (float)0x10000;
- else
- ziscale = (float)0x8000 * (float)0x10000 * 3.0;
- if (currententity->trivial_accept)
- R_AliasPrepareUnclippedPoints ();
- else
- R_AliasPreparePoints ();
- }
|