123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719 |
- #include "Precompiled.h"
- #include "globaldata.h"
- #include <stdlib.h>
- #include "i_system.h"
- #include "doomdef.h"
- #include "doomstat.h"
- #include "r_local.h"
- #include "r_sky.h"
- void
- R_RenderMaskedSegRange
- ( drawseg_t* ds,
- int x1,
- int x2 )
- {
- unsigned index;
- postColumn_t* col;
- int lightnum;
- int texnum;
-
-
-
-
-
- ::g->curline = ds->curline;
- ::g->frontsector = ::g->curline->frontsector;
- ::g->backsector = ::g->curline->backsector;
- texnum = ::g->texturetranslation[::g->curline->sidedef->midtexture];
-
- lightnum = (::g->frontsector->lightlevel >> LIGHTSEGSHIFT)+::g->extralight;
- if (::g->curline->v1->y == ::g->curline->v2->y)
- lightnum--;
- else if (::g->curline->v1->x == ::g->curline->v2->x)
- lightnum++;
- if (lightnum < 0)
- ::g->walllights = ::g->scalelight[0];
- else if (lightnum >= LIGHTLEVELS)
- ::g->walllights = ::g->scalelight[LIGHTLEVELS-1];
- else
- ::g->walllights = ::g->scalelight[lightnum];
- ::g->maskedtexturecol = ds->maskedtexturecol;
- ::g->rw_scalestep = ds->scalestep;
- ::g->spryscale = ds->scale1 + (x1 - ds->x1)*::g->rw_scalestep;
- ::g->mfloorclip = ds->sprbottomclip;
- ::g->mceilingclip = ds->sprtopclip;
-
-
- if (::g->curline->linedef->flags & ML_DONTPEGBOTTOM)
- {
- ::g->dc_texturemid = ::g->frontsector->floorheight > ::g->backsector->floorheight
- ? ::g->frontsector->floorheight : ::g->backsector->floorheight;
- ::g->dc_texturemid = ::g->dc_texturemid + ::g->s_textureheight[texnum] - ::g->viewz;
- }
- else
- {
- ::g->dc_texturemid =::g->frontsector->ceilingheight < ::g->backsector->ceilingheight
- ? ::g->frontsector->ceilingheight : ::g->backsector->ceilingheight;
- ::g->dc_texturemid = ::g->dc_texturemid - ::g->viewz;
- }
- ::g->dc_texturemid += ::g->curline->sidedef->rowoffset;
-
- if (::g->fixedcolormap)
- ::g->dc_colormap = ::g->fixedcolormap;
-
-
- for (::g->dc_x = x1 ; ::g->dc_x <= x2 ; ::g->dc_x++)
- {
-
- if (::g->maskedtexturecol[::g->dc_x] != SHRT_MAX)
- {
- if (!::g->fixedcolormap)
- {
- index = ::g->spryscale>>LIGHTSCALESHIFT;
- if (index >= MAXLIGHTSCALE )
- index = MAXLIGHTSCALE-1;
- ::g->dc_colormap = ::g->walllights[index];
- }
-
- ::g->sprtopscreen = ::g->centeryfrac - FixedMul(::g->dc_texturemid, ::g->spryscale);
- ::g->dc_iscale = 0xffffffffu / (unsigned)::g->spryscale;
-
-
- col = (postColumn_t *)(
- (byte *)R_GetColumn(texnum,::g->maskedtexturecol[::g->dc_x]) -3);
-
- R_DrawMaskedColumn (col);
- ::g->maskedtexturecol[::g->dc_x] = SHRT_MAX;
- }
- ::g->spryscale += ::g->rw_scalestep;
- }
-
- }
- void R_RenderSegLoop (void)
- {
- angle_t angle;
- unsigned index;
- int yl;
- int yh;
- int mid;
- fixed_t texturecolumn;
- int top;
- int bottom;
- texturecolumn = 0;
-
- for ( ; ::g->rw_x < ::g->rw_stopx ; ::g->rw_x++)
- {
-
- yl = (::g->topfrac+HEIGHTUNIT-1)>>HEIGHTBITS;
-
- if (yl < ::g->ceilingclip[::g->rw_x]+1)
- yl = ::g->ceilingclip[::g->rw_x]+1;
-
- if (::g->markceiling)
- {
- top = ::g->ceilingclip[::g->rw_x]+1;
- bottom = yl-1;
- if (bottom >= ::g->floorclip[::g->rw_x])
- bottom = ::g->floorclip[::g->rw_x]-1;
- if (top <= bottom)
- {
- ::g->ceilingplane->top[::g->rw_x] = top;
- ::g->ceilingplane->bottom[::g->rw_x] = bottom;
- }
- }
-
- yh = ::g->bottomfrac>>HEIGHTBITS;
- if (yh >= ::g->floorclip[::g->rw_x])
- yh = ::g->floorclip[::g->rw_x]-1;
- if (::g->markfloor)
- {
- top = yh+1;
- bottom = ::g->floorclip[::g->rw_x]-1;
- if (top <= ::g->ceilingclip[::g->rw_x])
- top = ::g->ceilingclip[::g->rw_x]+1;
- if (top <= bottom)
- {
- ::g->floorplane->top[::g->rw_x] = top;
- ::g->floorplane->bottom[::g->rw_x] = bottom;
- }
- }
-
-
- if (::g->segtextured)
- {
-
- angle = (::g->rw_centerangle + ::g->xtoviewangle[::g->rw_x])>>ANGLETOFINESHIFT;
- texturecolumn = ::g->rw_offset-FixedMul(finetangent[angle],::g->rw_distance);
- texturecolumn >>= FRACBITS;
-
- index = ::g->rw_scale>>LIGHTSCALESHIFT;
- if (index >= MAXLIGHTSCALE )
- index = MAXLIGHTSCALE-1;
- ::g->dc_colormap = ::g->walllights[index];
- ::g->dc_x = ::g->rw_x;
- ::g->dc_iscale = 0xffffffffu / (unsigned)::g->rw_scale;
- }
-
-
- if (::g->midtexture)
- {
-
- ::g->dc_yl = yl;
- ::g->dc_yh = yh;
- ::g->dc_texturemid = ::g->rw_midtexturemid;
- ::g->dc_source = R_GetColumn(::g->midtexture,texturecolumn);
- colfunc ( ::g->dc_colormap, ::g->dc_source );
- ::g->ceilingclip[::g->rw_x] = ::g->viewheight;
- ::g->floorclip[::g->rw_x] = -1;
- }
- else
- {
-
- if (::g->toptexture)
- {
-
- mid = ::g->pixhigh>>HEIGHTBITS;
- ::g->pixhigh += ::g->pixhighstep;
- if (mid >= ::g->floorclip[::g->rw_x])
- mid = ::g->floorclip[::g->rw_x]-1;
- if (mid >= yl)
- {
- ::g->dc_yl = yl;
- ::g->dc_yh = mid;
- ::g->dc_texturemid = ::g->rw_toptexturemid;
- ::g->dc_source = R_GetColumn(::g->toptexture,texturecolumn);
- colfunc ( ::g->dc_colormap, ::g->dc_source );
- ::g->ceilingclip[::g->rw_x] = mid;
- }
- else
- ::g->ceilingclip[::g->rw_x] = yl-1;
- }
- else
- {
-
- if (::g->markceiling)
- ::g->ceilingclip[::g->rw_x] = yl-1;
- }
-
- if (::g->bottomtexture)
- {
-
- mid = (::g->pixlow+HEIGHTUNIT-1)>>HEIGHTBITS;
- ::g->pixlow += ::g->pixlowstep;
-
- if (mid <= ::g->ceilingclip[::g->rw_x])
- mid = ::g->ceilingclip[::g->rw_x]+1;
-
- if (mid <= yh)
- {
- ::g->dc_yl = mid;
- ::g->dc_yh = yh;
- ::g->dc_texturemid = ::g->rw_bottomtexturemid;
- ::g->dc_source = R_GetColumn(::g->bottomtexture,
- texturecolumn);
- colfunc ( ::g->dc_colormap, ::g->dc_source );
- ::g->floorclip[::g->rw_x] = mid;
- }
- else
- ::g->floorclip[::g->rw_x] = yh+1;
- }
- else
- {
-
- if (::g->markfloor)
- ::g->floorclip[::g->rw_x] = yh+1;
- }
-
- if (::g->maskedtexture)
- {
-
-
- ::g->maskedtexturecol[::g->rw_x] = texturecolumn;
- }
- }
-
- ::g->rw_scale += ::g->rw_scalestep;
- ::g->topfrac += ::g->topstep;
- ::g->bottomfrac += ::g->bottomstep;
- }
- }
- void
- R_StoreWallRange
- ( int start,
- int stop )
- {
- fixed_t hyp;
- fixed_t sineval;
- angle_t distangle, offsetangle;
- fixed_t vtop;
- int lightnum;
-
- if (::g->ds_p == &::g->drawsegs[MAXDRAWSEGS])
- return;
-
- #ifdef RANGECHECK
- if (start >=::g->viewwidth || start > stop)
- I_Error ("Bad R_RenderWallRange: %i to %i", start , stop);
- #endif
-
- ::g->sidedef = ::g->curline->sidedef;
- ::g->linedef = ::g->curline->linedef;
-
- ::g->linedef->flags |= ML_MAPPED;
-
-
- ::g->rw_normalangle = ::g->curline->angle + ANG90;
- offsetangle = abs((long)(::g->rw_normalangle-::g->rw_angle1));
-
- if (offsetangle > ANG90)
- offsetangle = ANG90;
- distangle = ANG90 - offsetangle;
- hyp = R_PointToDist (::g->curline->v1->x, ::g->curline->v1->y);
- sineval = finesine[distangle>>ANGLETOFINESHIFT];
- ::g->rw_distance = FixedMul (hyp, sineval);
-
-
- ::g->ds_p->x1 = ::g->rw_x = start;
- ::g->ds_p->x2 = stop;
- ::g->ds_p->curline = ::g->curline;
- ::g->rw_stopx = stop+1;
-
-
- extern angle_t GetViewAngle();
- ::g->ds_p->scale1 = ::g->rw_scale =
- R_ScaleFromGlobalAngle (GetViewAngle() + ::g->xtoviewangle[start]);
-
- if (stop > start )
- {
- ::g->ds_p->scale2 = R_ScaleFromGlobalAngle (GetViewAngle() + ::g->xtoviewangle[stop]);
- ::g->ds_p->scalestep = ::g->rw_scalestep =
- (::g->ds_p->scale2 - ::g->rw_scale) / (stop-start);
- }
- else
- {
-
- #if 0
- if (::g->rw_distance < FRACUNIT/2)
- {
- fixed_t trx,try;
- fixed_t gxt,gyt;
- extern fixed_t GetViewX(); extern fixed_t GetViewY();
- trx = ::g->curline->v1->x - GetViewX();
- try = ::g->curline->v1->y - GetVewY();
-
- gxt = FixedMul(trx,::g->viewcos);
- gyt = -FixedMul(try,::g->viewsin);
- ::g->ds_p->scale1 = FixedDiv(::g->projection, gxt-gyt) << ::g->detailshift;
- }
- #endif
- ::g->ds_p->scale2 = ::g->ds_p->scale1;
- }
-
-
-
- ::g->worldtop = ::g->frontsector->ceilingheight - ::g->viewz;
- ::g->worldbottom = ::g->frontsector->floorheight - ::g->viewz;
-
- ::g->midtexture = ::g->toptexture = ::g->bottomtexture = ::g->maskedtexture = 0;
- ::g->ds_p->maskedtexturecol = NULL;
-
- if (!::g->backsector)
- {
-
- ::g->midtexture = ::g->texturetranslation[::g->sidedef->midtexture];
-
- ::g->markfloor = ::g->markceiling = true;
- if (::g->linedef->flags & ML_DONTPEGBOTTOM)
- {
- vtop = ::g->frontsector->floorheight +
- ::g->s_textureheight[::g->sidedef->midtexture];
-
- ::g->rw_midtexturemid = vtop - ::g->viewz;
- }
- else
- {
-
- ::g->rw_midtexturemid = ::g->worldtop;
- }
- ::g->rw_midtexturemid += ::g->sidedef->rowoffset;
- ::g->ds_p->silhouette = SIL_BOTH;
- ::g->ds_p->sprtopclip = ::g->screenheightarray;
- ::g->ds_p->sprbottomclip = ::g->negonearray;
- ::g->ds_p->bsilheight = MAXINT;
- ::g->ds_p->tsilheight = MININT;
- }
- else
- {
-
- ::g->ds_p->sprtopclip = ::g->ds_p->sprbottomclip = NULL;
- ::g->ds_p->silhouette = 0;
-
- if (::g->frontsector->floorheight > ::g->backsector->floorheight)
- {
- ::g->ds_p->silhouette = SIL_BOTTOM;
- ::g->ds_p->bsilheight = ::g->frontsector->floorheight;
- }
- else if (::g->backsector->floorheight > ::g->viewz)
- {
- ::g->ds_p->silhouette = SIL_BOTTOM;
- ::g->ds_p->bsilheight = MAXINT;
-
- }
-
- if (::g->frontsector->ceilingheight < ::g->backsector->ceilingheight)
- {
- ::g->ds_p->silhouette |= SIL_TOP;
- ::g->ds_p->tsilheight = ::g->frontsector->ceilingheight;
- }
- else if (::g->backsector->ceilingheight < ::g->viewz)
- {
- ::g->ds_p->silhouette |= SIL_TOP;
- ::g->ds_p->tsilheight = MININT;
-
- }
-
- if (::g->backsector->ceilingheight <= ::g->frontsector->floorheight)
- {
- ::g->ds_p->sprbottomclip = ::g->negonearray;
- ::g->ds_p->bsilheight = MAXINT;
- ::g->ds_p->silhouette |= SIL_BOTTOM;
- }
-
- if (::g->backsector->floorheight >= ::g->frontsector->ceilingheight)
- {
- ::g->ds_p->sprtopclip = ::g->screenheightarray;
- ::g->ds_p->tsilheight = MININT;
- ::g->ds_p->silhouette |= SIL_TOP;
- }
-
- ::g->worldhigh = ::g->backsector->ceilingheight - ::g->viewz;
- ::g->worldlow = ::g->backsector->floorheight - ::g->viewz;
-
-
- if (::g->frontsector->ceilingpic == ::g->skyflatnum
- && ::g->backsector->ceilingpic == ::g->skyflatnum)
- {
- ::g->worldtop = ::g->worldhigh;
- }
-
-
- if (::g->worldlow != ::g->worldbottom
- || ::g->backsector->floorpic != ::g->frontsector->floorpic
- || ::g->backsector->lightlevel != ::g->frontsector->lightlevel)
- {
- ::g->markfloor = true;
- }
- else
- {
-
- ::g->markfloor = false;
- }
-
-
- if (::g->worldhigh != ::g->worldtop
- || ::g->backsector->ceilingpic != ::g->frontsector->ceilingpic
- || ::g->backsector->lightlevel != ::g->frontsector->lightlevel)
- {
- ::g->markceiling = true;
- }
- else
- {
-
- ::g->markceiling = false;
- }
-
- if (::g->backsector->ceilingheight <= ::g->frontsector->floorheight
- || ::g->backsector->floorheight >= ::g->frontsector->ceilingheight)
- {
-
- ::g->markceiling = ::g->markfloor = true;
- }
-
- if (::g->worldhigh < ::g->worldtop)
- {
-
- ::g->toptexture = ::g->texturetranslation[::g->sidedef->toptexture];
- if (::g->linedef->flags & ML_DONTPEGTOP)
- {
-
- ::g->rw_toptexturemid = ::g->worldtop;
- }
- else
- {
- vtop =
- ::g->backsector->ceilingheight
- + ::g->s_textureheight[::g->sidedef->toptexture];
-
-
- ::g->rw_toptexturemid = vtop - ::g->viewz;
- }
- }
- if (::g->worldlow > ::g->worldbottom)
- {
-
- ::g->bottomtexture = ::g->texturetranslation[::g->sidedef->bottomtexture];
- if (::g->linedef->flags & ML_DONTPEGBOTTOM )
- {
-
-
- ::g->rw_bottomtexturemid = ::g->worldtop;
- }
- else
- ::g->rw_bottomtexturemid = ::g->worldlow;
- }
- ::g->rw_toptexturemid += ::g->sidedef->rowoffset;
- ::g->rw_bottomtexturemid += ::g->sidedef->rowoffset;
-
-
- if (::g->sidedef->midtexture)
- {
-
- ::g->maskedtexture = true;
- ::g->ds_p->maskedtexturecol = ::g->maskedtexturecol = ::g->lastopening - ::g->rw_x;
- ::g->lastopening += ::g->rw_stopx - ::g->rw_x;
- }
- }
-
-
- ::g->segtextured = ::g->midtexture | ::g->toptexture | ::g->bottomtexture | ::g->maskedtexture;
- if (::g->segtextured)
- {
- offsetangle = ::g->rw_normalangle-::g->rw_angle1;
-
- if (offsetangle > ANG180)
- offsetangle = -offsetangle;
- if (offsetangle > ANG90)
- offsetangle = ANG90;
- sineval = finesine[offsetangle >>ANGLETOFINESHIFT];
- ::g->rw_offset = FixedMul (hyp, sineval);
- if (::g->rw_normalangle-::g->rw_angle1 < ANG180)
- ::g->rw_offset = -::g->rw_offset;
- ::g->rw_offset += ::g->sidedef->textureoffset + ::g->curline->offset;
- ::g->rw_centerangle = ANG90 + GetViewAngle() - ::g->rw_normalangle;
-
-
-
-
-
- if (!::g->fixedcolormap)
- {
- lightnum = (::g->frontsector->lightlevel >> LIGHTSEGSHIFT)+::g->extralight;
- if (::g->curline->v1->y == ::g->curline->v2->y)
- lightnum--;
- else if (::g->curline->v1->x == ::g->curline->v2->x)
- lightnum++;
- if (lightnum < 0)
- ::g->walllights = ::g->scalelight[0];
- else if (lightnum >= LIGHTLEVELS)
- ::g->walllights = ::g->scalelight[LIGHTLEVELS-1];
- else
- ::g->walllights = ::g->scalelight[lightnum];
- }
- }
-
-
-
-
-
-
- if (::g->frontsector->floorheight >= ::g->viewz)
- {
-
- ::g->markfloor = false;
- }
-
- if (::g->frontsector->ceilingheight <= ::g->viewz
- && ::g->frontsector->ceilingpic != ::g->skyflatnum)
- {
-
- ::g->markceiling = false;
- }
-
-
- ::g->worldtop >>= 4;
- ::g->worldbottom >>= 4;
-
- ::g->topstep = -FixedMul (::g->rw_scalestep, ::g->worldtop);
- ::g->topfrac = (::g->centeryfrac>>4) - FixedMul (::g->worldtop, ::g->rw_scale);
- ::g->bottomstep = -FixedMul (::g->rw_scalestep,::g->worldbottom);
- ::g->bottomfrac = (::g->centeryfrac>>4) - FixedMul (::g->worldbottom, ::g->rw_scale);
-
- if (::g->backsector)
- {
- ::g->worldhigh >>= 4;
- ::g->worldlow >>= 4;
- if (::g->worldhigh < ::g->worldtop)
- {
- ::g->pixhigh = (::g->centeryfrac>>4) - FixedMul (::g->worldhigh, ::g->rw_scale);
- ::g->pixhighstep = -FixedMul (::g->rw_scalestep,::g->worldhigh);
- }
-
- if (::g->worldlow > ::g->worldbottom)
- {
- ::g->pixlow = (::g->centeryfrac>>4) - FixedMul (::g->worldlow, ::g->rw_scale);
- ::g->pixlowstep = -FixedMul (::g->rw_scalestep,::g->worldlow);
- }
- }
-
-
- if (::g->markceiling)
- ::g->ceilingplane = R_CheckPlane (::g->ceilingplane, ::g->rw_x, ::g->rw_stopx-1);
- if (::g->markfloor)
- ::g->floorplane = R_CheckPlane (::g->floorplane, ::g->rw_x, ::g->rw_stopx-1);
- R_RenderSegLoop ();
-
-
- if ( ((::g->ds_p->silhouette & SIL_TOP) || ::g->maskedtexture)
- && !::g->ds_p->sprtopclip)
- {
- memcpy (::g->lastopening, ::g->ceilingclip+start, 2*(::g->rw_stopx-start));
- ::g->ds_p->sprtopclip = ::g->lastopening - start;
- ::g->lastopening += ::g->rw_stopx - start;
- }
-
- if ( ((::g->ds_p->silhouette & SIL_BOTTOM) || ::g->maskedtexture)
- && !::g->ds_p->sprbottomclip)
- {
- memcpy (::g->lastopening, ::g->floorclip+start, 2*(::g->rw_stopx-start));
- ::g->ds_p->sprbottomclip = ::g->lastopening - start;
- ::g->lastopening += ::g->rw_stopx - start;
- }
- if (::g->maskedtexture && !(::g->ds_p->silhouette&SIL_TOP))
- {
- ::g->ds_p->silhouette |= SIL_TOP;
- ::g->ds_p->tsilheight = MININT;
- }
- if (::g->maskedtexture && !(::g->ds_p->silhouette&SIL_BOTTOM))
- {
- ::g->ds_p->silhouette |= SIL_BOTTOM;
- ::g->ds_p->bsilheight = MAXINT;
- }
- ::g->ds_p++;
- }
|