1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354 |
- #include "Precompiled.h"
- #include "globaldata.h"
- #include <stdlib.h>
- #include "m_bbox.h"
- #include "m_random.h"
- #include "i_system.h"
- #include "doomdef.h"
- #include "p_local.h"
- #include "s_sound.h"
- #include "doomstat.h"
- #include "r_state.h"
- #include "sounds.h"
- #include "Main.h"
- qboolean PIT_StompThing (mobj_t* thing)
- {
- fixed_t blockdist;
-
- if (!(thing->flags & MF_SHOOTABLE) )
- return true;
-
- blockdist = thing->radius + ::g->tmthing->radius;
-
- if ( abs(thing->x - ::g->tmx) >= blockdist
- || abs(thing->y - ::g->tmy) >= blockdist )
- {
-
- return true;
- }
-
-
- if (thing == ::g->tmthing)
- return true;
-
-
- if ( !::g->tmthing->player && ::g->gamemap != 30)
- return false;
-
- P_DamageMobj (thing, ::g->tmthing, ::g->tmthing, 10000);
-
- return true;
- }
- qboolean
- P_TeleportMove
- ( mobj_t* thing,
- fixed_t x,
- fixed_t y )
- {
- int xl;
- int xh;
- int yl;
- int yh;
- int bx;
- int by;
-
- subsector_t* newsubsec;
-
-
- ::g->tmthing = thing;
- ::g->tmflags = thing->flags;
-
- ::g->tmx = x;
- ::g->tmy = y;
-
- ::g->tmbbox[BOXTOP] = y + ::g->tmthing->radius;
- ::g->tmbbox[BOXBOTTOM] = y - ::g->tmthing->radius;
- ::g->tmbbox[BOXRIGHT] = x + ::g->tmthing->radius;
- ::g->tmbbox[BOXLEFT] = x - ::g->tmthing->radius;
- newsubsec = R_PointInSubsector (x,y);
- ::g->ceilingline = NULL;
-
-
-
-
-
- ::g->tmfloorz = ::g->tmdropoffz = newsubsec->sector->floorheight;
- ::g->tmceilingz = newsubsec->sector->ceilingheight;
-
- ::g->validcount++;
- ::g->numspechit = 0;
-
-
- xl = (::g->tmbbox[BOXLEFT] - ::g->bmaporgx - MAXRADIUS)>>MAPBLOCKSHIFT;
- xh = (::g->tmbbox[BOXRIGHT] - ::g->bmaporgx + MAXRADIUS)>>MAPBLOCKSHIFT;
- yl = (::g->tmbbox[BOXBOTTOM] - ::g->bmaporgy - MAXRADIUS)>>MAPBLOCKSHIFT;
- yh = (::g->tmbbox[BOXTOP] - ::g->bmaporgy + MAXRADIUS)>>MAPBLOCKSHIFT;
- for (bx=xl ; bx<=xh ; bx++)
- for (by=yl ; by<=yh ; by++)
- if (!P_BlockThingsIterator(bx,by,PIT_StompThing))
- return false;
-
-
-
- P_UnsetThingPosition (thing);
- thing->floorz = ::g->tmfloorz;
- thing->ceilingz = ::g->tmceilingz;
- thing->x = x;
- thing->y = y;
- P_SetThingPosition (thing);
-
- return true;
- }
- qboolean PIT_CheckLine (line_t* ld)
- {
- if (::g->tmbbox[BOXRIGHT] <= ld->bbox[BOXLEFT]
- || ::g->tmbbox[BOXLEFT] >= ld->bbox[BOXRIGHT]
- || ::g->tmbbox[BOXTOP] <= ld->bbox[BOXBOTTOM]
- || ::g->tmbbox[BOXBOTTOM] >= ld->bbox[BOXTOP] )
- return true;
- if (P_BoxOnLineSide (::g->tmbbox, ld) != -1)
- return true;
-
-
-
-
-
-
-
-
-
-
-
-
- if (!ld->backsector)
- return false;
-
- if (!(::g->tmthing->flags & MF_MISSILE) )
- {
- if ( ld->flags & ML_BLOCKING )
- return false;
- if ( !::g->tmthing->player && ld->flags & ML_BLOCKMONSTERS )
- return false;
- }
-
- P_LineOpening (ld);
-
-
- if (::g->opentop < ::g->tmceilingz)
- {
- ::g->tmceilingz = ::g->opentop;
- ::g->ceilingline = ld;
- }
- if (::g->openbottom > ::g->tmfloorz)
- ::g->tmfloorz = ::g->openbottom;
- if (::g->lowfloor < ::g->tmdropoffz)
- ::g->tmdropoffz = ::g->lowfloor;
-
- if (ld->special && ::g->numspechit < MAXSPECIALCROSS )
- {
- ::g->spechit[::g->numspechit] = ld;
- ::g->numspechit++;
- }
- return true;
- }
- qboolean PIT_CheckThing (mobj_t* thing)
- {
- fixed_t blockdist;
- qboolean solid;
- int damage;
-
- if (!(thing->flags & (MF_SOLID|MF_SPECIAL|MF_SHOOTABLE) ))
- return true;
-
- blockdist = thing->radius + ::g->tmthing->radius;
- if ( abs(thing->x - ::g->tmx) >= blockdist
- || abs(thing->y - ::g->tmy) >= blockdist )
- {
-
- return true;
- }
-
-
- if (thing == ::g->tmthing)
- return true;
-
-
- if (::g->tmthing->flags & MF_SKULLFLY)
- {
- damage = ((P_Random()%8)+1)*::g->tmthing->info->damage;
-
- P_DamageMobj (thing, ::g->tmthing, ::g->tmthing, damage);
-
- ::g->tmthing->flags &= ~MF_SKULLFLY;
- ::g->tmthing->momx = ::g->tmthing->momy = ::g->tmthing->momz = 0;
-
- P_SetMobjState (::g->tmthing, (statenum_t)::g->tmthing->info->spawnstate);
-
- return false;
- }
-
-
- if (::g->tmthing->flags & MF_MISSILE)
- {
-
- if (::g->tmthing->z > thing->z + thing->height)
- return true;
- if (::g->tmthing->z+::g->tmthing->height < thing->z)
- return true;
-
- if (::g->tmthing->target && (
- ::g->tmthing->target->type == thing->type ||
- (::g->tmthing->target->type == MT_KNIGHT && thing->type == MT_BRUISER)||
- (::g->tmthing->target->type == MT_BRUISER && thing->type == MT_KNIGHT) ) )
- {
-
- if (thing == ::g->tmthing->target)
- return true;
- if (thing->type != MT_PLAYER)
- {
-
-
- return false;
- }
- }
-
- if (! (thing->flags & MF_SHOOTABLE) )
- {
-
- return !(thing->flags & MF_SOLID);
- }
-
-
- damage = ((P_Random()%8)+1)*::g->tmthing->info->damage;
- P_DamageMobj (thing, ::g->tmthing, ::g->tmthing->target, damage);
-
- return false;
- }
-
-
- if (thing->flags & MF_SPECIAL)
- {
- solid = thing->flags&MF_SOLID;
- if (::g->tmflags&MF_PICKUP)
- {
-
- P_TouchSpecialThing (thing, ::g->tmthing);
- }
- return !solid;
- }
-
- return !(thing->flags & MF_SOLID);
- }
- qboolean
- P_CheckPosition
- ( mobj_t* thing,
- fixed_t x,
- fixed_t y )
- {
- int xl;
- int xh;
- int yl;
- int yh;
- int bx;
- int by;
- subsector_t* newsubsec;
- ::g->tmthing = thing;
- ::g->tmflags = thing->flags;
-
- ::g->tmx = x;
- ::g->tmy = y;
-
- ::g->tmbbox[BOXTOP] = y + ::g->tmthing->radius;
- ::g->tmbbox[BOXBOTTOM] = y - ::g->tmthing->radius;
- ::g->tmbbox[BOXRIGHT] = x + ::g->tmthing->radius;
- ::g->tmbbox[BOXLEFT] = x - ::g->tmthing->radius;
- newsubsec = R_PointInSubsector (x,y);
- ::g->ceilingline = NULL;
-
-
-
-
-
- ::g->tmfloorz = ::g->tmdropoffz = newsubsec->sector->floorheight;
- ::g->tmceilingz = newsubsec->sector->ceilingheight;
-
- ::g->validcount++;
- ::g->numspechit = 0;
- if ( ::g->tmflags & MF_NOCLIP )
- return true;
-
-
-
-
-
-
- xl = (::g->tmbbox[BOXLEFT] - ::g->bmaporgx - MAXRADIUS)>>MAPBLOCKSHIFT;
- xh = (::g->tmbbox[BOXRIGHT] - ::g->bmaporgx + MAXRADIUS)>>MAPBLOCKSHIFT;
- yl = (::g->tmbbox[BOXBOTTOM] - ::g->bmaporgy - MAXRADIUS)>>MAPBLOCKSHIFT;
- yh = (::g->tmbbox[BOXTOP] - ::g->bmaporgy + MAXRADIUS)>>MAPBLOCKSHIFT;
- for (bx=xl ; bx<=xh ; bx++)
- for (by=yl ; by<=yh ; by++)
- if (!P_BlockThingsIterator(bx,by,PIT_CheckThing))
- return false;
-
-
- xl = (::g->tmbbox[BOXLEFT] - ::g->bmaporgx)>>MAPBLOCKSHIFT;
- xh = (::g->tmbbox[BOXRIGHT] - ::g->bmaporgx)>>MAPBLOCKSHIFT;
- yl = (::g->tmbbox[BOXBOTTOM] - ::g->bmaporgy)>>MAPBLOCKSHIFT;
- yh = (::g->tmbbox[BOXTOP] - ::g->bmaporgy)>>MAPBLOCKSHIFT;
- for (bx=xl ; bx<=xh ; bx++)
- for (by=yl ; by<=yh ; by++)
- if (!P_BlockLinesIterator (bx,by,PIT_CheckLine))
- return false;
- return true;
- }
- qboolean
- P_TryMove
- ( mobj_t* thing,
- fixed_t x,
- fixed_t y )
- {
- fixed_t oldx;
- fixed_t oldy;
- int side;
- int oldside;
- line_t* ld;
- ::g->floatok = false;
- if (!P_CheckPosition (thing, x, y))
- return false;
-
- if ( !(thing->flags & MF_NOCLIP) )
- {
- if (::g->tmceilingz - ::g->tmfloorz < thing->height)
- return false;
- ::g->floatok = true;
-
- if ( !(thing->flags&MF_TELEPORT)
- &&::g->tmceilingz - thing->z < thing->height)
- return false;
- if ( !(thing->flags&MF_TELEPORT)
- && ::g->tmfloorz - thing->z > 24*FRACUNIT )
- return false;
- if ( !(thing->flags&(MF_DROPOFF|MF_FLOAT))
- && ::g->tmfloorz - ::g->tmdropoffz > 24*FRACUNIT )
- return false;
- }
-
-
-
- P_UnsetThingPosition (thing);
- oldx = thing->x;
- oldy = thing->y;
- thing->floorz = ::g->tmfloorz;
- thing->ceilingz = ::g->tmceilingz;
- thing->x = x;
- thing->y = y;
- P_SetThingPosition (thing);
-
-
- if (! (thing->flags&(MF_TELEPORT|MF_NOCLIP)) )
- {
- while (::g->numspechit--)
- {
-
- ld = ::g->spechit[::g->numspechit];
- side = P_PointOnLineSide (thing->x, thing->y, ld);
- oldside = P_PointOnLineSide (oldx, oldy, ld);
- if (side != oldside)
- {
- if (ld->special)
- P_CrossSpecialLine (ld-::g->lines, oldside, thing);
- }
- }
- }
- return true;
- }
- qboolean P_ThingHeightClip (mobj_t* thing)
- {
- qboolean onfloor;
-
- onfloor = (thing->z == thing->floorz);
-
- P_CheckPosition (thing, thing->x, thing->y);
-
-
- thing->floorz = ::g->tmfloorz;
- thing->ceilingz = ::g->tmceilingz;
-
- if (onfloor)
- {
-
- thing->z = thing->floorz;
- }
- else
- {
-
- if (thing->z+thing->height > thing->ceilingz)
- thing->z = thing->ceilingz - thing->height;
- }
-
- if (thing->ceilingz - thing->floorz < thing->height)
- return false;
-
- return true;
- }
- void P_HitSlideLine (line_t* ld)
- {
- int side;
- angle_t lineangle;
- angle_t moveangle;
- angle_t deltaangle;
-
- fixed_t movelen;
- fixed_t newlen;
-
-
- if (ld->slopetype == ST_HORIZONTAL)
- {
- ::g->tmymove = 0;
- return;
- }
-
- if (ld->slopetype == ST_VERTICAL)
- {
- ::g->tmxmove = 0;
- return;
- }
-
- side = P_PointOnLineSide (::g->slidemo->x, ::g->slidemo->y, ld);
-
- lineangle = R_PointToAngle2 (0,0, ld->dx, ld->dy);
- if (side == 1)
- lineangle += ANG180;
- moveangle = R_PointToAngle2 (0,0, ::g->tmxmove, ::g->tmymove);
- deltaangle = moveangle-lineangle;
- if (deltaangle > ANG180)
- deltaangle += ANG180;
-
- lineangle >>= ANGLETOFINESHIFT;
- deltaangle >>= ANGLETOFINESHIFT;
-
- movelen = P_AproxDistance (::g->tmxmove, ::g->tmymove);
- newlen = FixedMul (movelen, finecosine[deltaangle]);
- ::g->tmxmove = FixedMul (newlen, finecosine[lineangle]);
- ::g->tmymove = FixedMul (newlen, finesine[lineangle]);
- }
- qboolean PTR_SlideTraverse (intercept_t* in)
- {
- line_t* li;
-
- if (!in->isaline)
- I_Error ("PTR_SlideTraverse: not a line?");
-
- li = in->d.line;
-
- if ( ! (li->flags & ML_TWOSIDED) )
- {
- if (P_PointOnLineSide (::g->slidemo->x, ::g->slidemo->y, li))
- {
-
- return true;
- }
- goto isblocking;
- }
-
- P_LineOpening (li);
-
- if (::g->openrange < ::g->slidemo->height)
- goto isblocking;
-
- if (::g->opentop - ::g->slidemo->z < ::g->slidemo->height)
- goto isblocking;
- if (::g->openbottom - ::g->slidemo->z > 24*FRACUNIT )
- goto isblocking;
-
- return true;
-
-
-
- isblocking:
- if (in->frac < ::g->bestslidefrac)
- {
- ::g->secondslidefrac = ::g->bestslidefrac;
- ::g->secondslideline = ::g->bestslideline;
- ::g->bestslidefrac = in->frac;
- ::g->bestslideline = li;
- }
-
- return false;
- }
- void P_SlideMove (mobj_t* mo)
- {
- fixed_t leadx;
- fixed_t leady;
- fixed_t trailx;
- fixed_t traily;
- fixed_t newx;
- fixed_t newy;
- int hitcount;
-
- ::g->slidemo = mo;
- hitcount = 0;
-
- retry:
- if (++hitcount == 3)
- goto stairstep;
-
-
- if (mo->momx > 0)
- {
- leadx = mo->x + mo->radius;
- trailx = mo->x - mo->radius;
- }
- else
- {
- leadx = mo->x - mo->radius;
- trailx = mo->x + mo->radius;
- }
-
- if (mo->momy > 0)
- {
- leady = mo->y + mo->radius;
- traily = mo->y - mo->radius;
- }
- else
- {
- leady = mo->y - mo->radius;
- traily = mo->y + mo->radius;
- }
-
- ::g->bestslidefrac = FRACUNIT+1;
-
- P_PathTraverse ( leadx, leady, leadx+mo->momx, leady+mo->momy,
- PT_ADDLINES, PTR_SlideTraverse );
- P_PathTraverse ( trailx, leady, trailx+mo->momx, leady+mo->momy,
- PT_ADDLINES, PTR_SlideTraverse );
- P_PathTraverse ( leadx, traily, leadx+mo->momx, traily+mo->momy,
- PT_ADDLINES, PTR_SlideTraverse );
-
-
- if (::g->bestslidefrac == FRACUNIT+1)
- {
-
- stairstep:
- if (!P_TryMove (mo, mo->x, mo->y + mo->momy))
- P_TryMove (mo, mo->x + mo->momx, mo->y);
- return;
- }
-
- ::g->bestslidefrac -= 0x800;
- if (::g->bestslidefrac > 0)
- {
- newx = FixedMul (mo->momx, ::g->bestslidefrac);
- newy = FixedMul (mo->momy, ::g->bestslidefrac);
-
- if (!P_TryMove (mo, mo->x+newx, mo->y+newy))
- goto stairstep;
- }
-
-
-
- ::g->bestslidefrac = FRACUNIT-(::g->bestslidefrac+0x800);
-
- if (::g->bestslidefrac > FRACUNIT)
- ::g->bestslidefrac = FRACUNIT;
-
- if (::g->bestslidefrac <= 0)
- return;
-
- ::g->tmxmove = FixedMul (mo->momx, ::g->bestslidefrac);
- ::g->tmymove = FixedMul (mo->momy, ::g->bestslidefrac);
- P_HitSlideLine (::g->bestslideline);
- mo->momx = ::g->tmxmove;
- mo->momy = ::g->tmymove;
-
- if (!P_TryMove (mo, mo->x+::g->tmxmove, mo->y+::g->tmymove))
- {
- goto retry;
- }
- }
- qboolean
- PTR_AimTraverse (intercept_t* in)
- {
- line_t* li;
- mobj_t* th;
- fixed_t slope;
- fixed_t thingtopslope;
- fixed_t thingbottomslope;
- fixed_t dist;
-
- if (in->isaline)
- {
- li = in->d.line;
-
- if ( !(li->flags & ML_TWOSIDED) )
- return false;
-
-
-
-
- P_LineOpening (li);
-
- if (::g->openbottom >= ::g->opentop)
- return false;
-
- dist = FixedMul (::g->attackrange, in->frac);
- if (li->frontsector->floorheight != li->backsector->floorheight)
- {
- slope = FixedDiv (::g->openbottom - ::g->shootz , dist);
- if (slope > ::g->bottomslope)
- ::g->bottomslope = slope;
- }
-
- if (li->frontsector->ceilingheight != li->backsector->ceilingheight)
- {
- slope = FixedDiv (::g->opentop - ::g->shootz , dist);
- if (slope < ::g->topslope)
- ::g->topslope = slope;
- }
-
- if (::g->topslope <= ::g->bottomslope)
- return false;
-
- return true;
- }
-
-
- th = in->d.thing;
- if (th == ::g->shootthing)
- return true;
-
- if (!(th->flags&MF_SHOOTABLE))
- return true;
-
- dist = FixedMul (::g->attackrange, in->frac);
- thingtopslope = FixedDiv (th->z+th->height - ::g->shootz , dist);
- if (thingtopslope < ::g->bottomslope)
- return true;
- thingbottomslope = FixedDiv (th->z - ::g->shootz, dist);
- if (thingbottomslope > ::g->topslope)
- return true;
-
-
- if (thingtopslope > ::g->topslope)
- thingtopslope = ::g->topslope;
-
- if (thingbottomslope < ::g->bottomslope)
- thingbottomslope = ::g->bottomslope;
- ::g->aimslope = (thingtopslope+thingbottomslope)/2;
- ::g->linetarget = th;
- return false;
- }
- qboolean PTR_ShootTraverse (intercept_t* in)
- {
- fixed_t x;
- fixed_t y;
- fixed_t z;
- fixed_t frac;
-
- line_t* li;
-
- mobj_t* th;
- fixed_t slope;
- fixed_t dist;
- fixed_t thingtopslope;
- fixed_t thingbottomslope;
-
- if (in->isaline)
- {
- li = in->d.line;
-
- if (li->special)
- P_ShootSpecialLine (::g->shootthing, li);
- if ( !(li->flags & ML_TWOSIDED) )
- goto hitline;
-
-
- P_LineOpening (li);
-
- dist = FixedMul (::g->attackrange, in->frac);
- if (li->frontsector->floorheight != li->backsector->floorheight)
- {
- slope = FixedDiv (::g->openbottom - ::g->shootz , dist);
- if (slope > ::g->aimslope)
- goto hitline;
- }
-
- if (li->frontsector->ceilingheight != li->backsector->ceilingheight)
- {
- slope = FixedDiv (::g->opentop - ::g->shootz , dist);
- if (slope < ::g->aimslope)
- goto hitline;
- }
-
- return true;
-
-
-
- hitline:
-
- frac = in->frac - FixedDiv (4*FRACUNIT,::g->attackrange);
- x = ::g->trace.x + FixedMul (::g->trace.dx, frac);
- y = ::g->trace.y + FixedMul (::g->trace.dy, frac);
- z = ::g->shootz + FixedMul (::g->aimslope, FixedMul(frac, ::g->attackrange));
- if (li->frontsector->ceilingpic == ::g->skyflatnum)
- {
-
- if (z > li->frontsector->ceilingheight)
- return false;
-
-
- if (li->backsector && li->backsector->ceilingpic == ::g->skyflatnum)
- return false;
- }
- mobj_t * sourceObject = ::g->shootthing;
- if( sourceObject ) {
- if( ( sourceObject->player) == &(::g->players[DoomLib::GetPlayer()]) ) {
-
-
- if( ::g->attackrange == MELEERANGE ) {
- }
- }
- }
-
- P_SpawnPuff (x,y,z);
-
-
- return false;
- }
-
-
- th = in->d.thing;
- if (th == ::g->shootthing)
- return true;
-
- if (!(th->flags&MF_SHOOTABLE))
- return true;
-
-
- dist = FixedMul (::g->attackrange, in->frac);
- thingtopslope = FixedDiv (th->z+th->height - ::g->shootz , dist);
- if (thingtopslope < ::g->aimslope)
- return true;
- thingbottomslope = FixedDiv (th->z - ::g->shootz, dist);
- if (thingbottomslope > ::g->aimslope)
- return true;
-
-
-
- frac = in->frac - FixedDiv (10*FRACUNIT,::g->attackrange);
- x = ::g->trace.x + FixedMul (::g->trace.dx, frac);
- y = ::g->trace.y + FixedMul (::g->trace.dy, frac);
- z = ::g->shootz + FixedMul (::g->aimslope, FixedMul(frac, ::g->attackrange));
-
- #ifdef ID_ENABLE_DOOM_CLASSIC_NETWORKING
- if( th && gameLocal->GetMatchParms().GetGameType() != GAME_TYPE_PVP ) {
- player_t * hitPlayer = th->player;
- if( hitPlayer ) {
- mobj_t * sourceObject = ::g->shootthing;
- if( sourceObject ) {
- player_t* sourcePlayer = sourceObject->player;
- if( sourcePlayer != NULL && sourcePlayer != hitPlayer && !gameLocal->GetMatchParms().AllowFriendlyFire() ) {
- return true;
- }
- }
- }
- }
- #endif
- mobj_t * sourceObject = ::g->shootthing;
- if( sourceObject ) {
- if( ( sourceObject->player) == &(::g->players[DoomLib::GetPlayer()]) ) {
-
- if( ::g->attackrange == MELEERANGE ) {
- }
- }
- }
-
-
- if (in->d.thing->flags & MF_NOBLOOD)
- P_SpawnPuff (x,y,z);
- else
- P_SpawnBlood (x,y,z, ::g->la_damage);
- if (::g->la_damage)
- P_DamageMobj (th, ::g->shootthing, ::g->shootthing, ::g->la_damage);
-
- return false;
-
- }
- fixed_t
- P_AimLineAttack
- ( mobj_t* t1,
- angle_t angle,
- fixed_t distance )
- {
- fixed_t x2;
- fixed_t y2;
-
- angle >>= ANGLETOFINESHIFT;
- ::g->shootthing = t1;
-
- x2 = t1->x + (distance>>FRACBITS)*finecosine[angle];
- y2 = t1->y + (distance>>FRACBITS)*finesine[angle];
- ::g->shootz = t1->z + (t1->height>>1) + 8*FRACUNIT;
-
- ::g->topslope = 100*FRACUNIT/160;
- ::g->bottomslope = -100*FRACUNIT/160;
-
- ::g->attackrange = distance;
- ::g->linetarget = NULL;
-
- P_PathTraverse ( t1->x, t1->y,
- x2, y2,
- PT_ADDLINES|PT_ADDTHINGS,
- PTR_AimTraverse );
-
- if (::g->linetarget)
- return ::g->aimslope;
- return 0;
- }
-
- void
- P_LineAttack
- ( mobj_t* t1,
- angle_t angle,
- fixed_t distance,
- fixed_t slope,
- int damage )
- {
- fixed_t x2;
- fixed_t y2;
-
- angle >>= ANGLETOFINESHIFT;
- ::g->shootthing = t1;
- ::g->la_damage = damage;
- x2 = t1->x + (distance>>FRACBITS)*finecosine[angle];
- y2 = t1->y + (distance>>FRACBITS)*finesine[angle];
- ::g->shootz = t1->z + (t1->height>>1) + 8*FRACUNIT;
- ::g->attackrange = distance;
- ::g->aimslope = slope;
-
- P_PathTraverse ( t1->x, t1->y,
- x2, y2,
- PT_ADDLINES|PT_ADDTHINGS,
- PTR_ShootTraverse );
- }
-
- qboolean PTR_UseTraverse (intercept_t* in)
- {
- int side;
-
- if (!in->d.line->special)
- {
- P_LineOpening (in->d.line);
- if (::g->openrange <= 0)
- {
- S_StartSound (::g->usething, sfx_noway);
-
-
- return false;
- }
-
- return true ;
- }
-
- side = 0;
- if (P_PointOnLineSide (::g->usething->x, ::g->usething->y, in->d.line) == 1)
- side = 1;
-
-
-
- P_UseSpecialLine (::g->usething, in->d.line, side);
-
- return false;
- }
- void P_UseLines (player_t* player)
- {
- int angle;
- fixed_t x1;
- fixed_t y1;
- fixed_t x2;
- fixed_t y2;
-
- ::g->usething = player->mo;
-
- angle = player->mo->angle >> ANGLETOFINESHIFT;
- x1 = player->mo->x;
- y1 = player->mo->y;
- x2 = x1 + (USERANGE>>FRACBITS)*finecosine[angle];
- y2 = y1 + (USERANGE>>FRACBITS)*finesine[angle];
-
- P_PathTraverse ( x1, y1, x2, y2, PT_ADDLINES, PTR_UseTraverse );
- }
- qboolean PIT_RadiusAttack (mobj_t* thing)
- {
- fixed_t dx;
- fixed_t dy;
- fixed_t dist;
-
- if (!(thing->flags & MF_SHOOTABLE) )
- return true;
-
-
- if (thing->type == MT_CYBORG
- || thing->type == MT_SPIDER)
- return true;
-
- dx = abs(thing->x - ::g->bombspot->x);
- dy = abs(thing->y - ::g->bombspot->y);
-
- dist = dx>dy ? dx : dy;
- dist = (dist - thing->radius) >> FRACBITS;
- if (dist < 0)
- dist = 0;
- if (dist >= ::g->bombdamage)
- return true;
- if ( P_CheckSight (thing, ::g->bombspot) )
- {
-
- P_DamageMobj (thing, ::g->bombspot, ::g->bombsource, ::g->bombdamage - dist);
- }
-
- return true;
- }
- void
- P_RadiusAttack
- ( mobj_t* spot,
- mobj_t* source,
- int damage )
- {
- int x;
- int y;
-
- int xl;
- int xh;
- int yl;
- int yh;
-
- fixed_t dist;
-
- dist = (damage+MAXRADIUS)<<FRACBITS;
- yh = (spot->y + dist - ::g->bmaporgy)>>MAPBLOCKSHIFT;
- yl = (spot->y - dist - ::g->bmaporgy)>>MAPBLOCKSHIFT;
- xh = (spot->x + dist - ::g->bmaporgx)>>MAPBLOCKSHIFT;
- xl = (spot->x - dist - ::g->bmaporgx)>>MAPBLOCKSHIFT;
- ::g->bombspot = spot;
- ::g->bombsource = source;
- ::g->bombdamage = damage;
-
- for (y=yl ; y<=yh ; y++)
- for (x=xl ; x<=xh ; x++)
- P_BlockThingsIterator (x, y, PIT_RadiusAttack );
- }
- qboolean PIT_ChangeSector (mobj_t* thing)
- {
- mobj_t* mo;
-
- if (P_ThingHeightClip (thing))
- {
-
- return true;
- }
-
-
- if (thing->health <= 0)
- {
- P_SetMobjState (thing, S_GIBS);
- thing->flags &= ~MF_SOLID;
- thing->height = 0;
- thing->radius = 0;
-
- return true;
- }
-
- if (thing->flags & MF_DROPPED)
- {
- P_RemoveMobj (thing);
-
-
- return true;
- }
- if (! (thing->flags & MF_SHOOTABLE) )
- {
-
- return true;
- }
-
- ::g->nofit = true;
- if (::g->crushchange && !(::g->leveltime&3) )
- {
- P_DamageMobj(thing,NULL,NULL,10);
-
- mo = P_SpawnMobj (thing->x,
- thing->y,
- thing->z + thing->height/2, MT_BLOOD);
-
- mo->momx = (P_Random() - P_Random ())<<12;
- mo->momy = (P_Random() - P_Random ())<<12;
- }
-
- return true;
- }
- qboolean
- P_ChangeSector
- ( sector_t* sector,
- qboolean crunch )
- {
- int x;
- int y;
-
- ::g->nofit = false;
- ::g->crushchange = crunch;
-
-
- for (x=sector->blockbox[BOXLEFT] ; x<= sector->blockbox[BOXRIGHT] ; x++)
- for (y=sector->blockbox[BOXBOTTOM];y<= sector->blockbox[BOXTOP] ; y++)
- P_BlockThingsIterator (x, y, PIT_ChangeSector);
-
-
- return ::g->nofit;
- }
|