2020-07-06 20:23:18 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "mathutil.h"
|
2021-04-11 06:40:18 +00:00
|
|
|
#include "gamehud.h"
|
2020-07-19 20:34:59 +00:00
|
|
|
#include "global.h"
|
2020-07-06 20:23:18 +00:00
|
|
|
|
|
|
|
// all inline functions.
|
|
|
|
BEGIN_DUKE_NS
|
|
|
|
|
2020-07-19 17:31:31 +00:00
|
|
|
inline int rnd(int X)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
return ((krand() >> 8) >= (255 - (X)));
|
2020-07-19 17:31:31 +00:00
|
|
|
}
|
|
|
|
|
2020-07-06 16:08:31 +00:00
|
|
|
inline bool AFLAMABLE(int X)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
return (X == TILE_BOX || X == TILE_TREE1 || X == TILE_TREE2 || X == TILE_TIRE || X == TILE_CONE);
|
2020-07-06 16:08:31 +00:00
|
|
|
}
|
2020-07-06 20:23:18 +00:00
|
|
|
|
|
|
|
inline int badguypic(int const tileNum)
|
|
|
|
{
|
2020-11-29 12:54:58 +00:00
|
|
|
return ((gs.actorinfo[tileNum].flags & (SFLAG_INTERNAL_BADGUY | SFLAG_BADGUY)) != 0);
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
2020-10-19 16:32:13 +00:00
|
|
|
inline int badguy(spritetype const * const pSprite)
|
2020-07-06 20:23:18 +00:00
|
|
|
{
|
2020-10-19 16:32:13 +00:00
|
|
|
return badguypic(pSprite->picnum);
|
2020-09-07 19:38:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline int bossguypic(int const tileNum)
|
|
|
|
{
|
2020-11-29 12:54:58 +00:00
|
|
|
return ((gs.actorinfo[tileNum].flags & (SFLAG_BOSS)) != 0);
|
2020-09-07 19:38:17 +00:00
|
|
|
}
|
|
|
|
|
2020-10-19 16:32:13 +00:00
|
|
|
inline int bossguy(spritetype const* const pSprite)
|
2020-09-07 19:38:17 +00:00
|
|
|
{
|
2020-10-19 16:32:13 +00:00
|
|
|
return bossguypic(pSprite->picnum);
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
2020-10-23 17:02:58 +00:00
|
|
|
inline int actorflag(DDukeActor * actor, int mask)
|
2020-07-06 16:08:31 +00:00
|
|
|
{
|
2021-04-15 17:21:43 +00:00
|
|
|
return (((gs.actorinfo[actor->s->picnum].flags) & mask) != 0);
|
2020-07-06 16:08:31 +00:00
|
|
|
}
|
|
|
|
|
2020-10-23 17:02:58 +00:00
|
|
|
inline int actorfella(DDukeActor* actor)
|
2020-07-06 16:08:31 +00:00
|
|
|
{
|
2020-10-23 17:02:58 +00:00
|
|
|
return actorflag(actor, SFLAG_KILLCOUNT);
|
2020-07-06 16:08:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline void setflag(int flag, const std::initializer_list<short>& types)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
for (auto val : types)
|
|
|
|
{
|
2020-11-29 12:54:58 +00:00
|
|
|
gs.actorinfo[val].flags |= flag;
|
2020-07-20 21:21:27 +00:00
|
|
|
}
|
2020-07-06 16:08:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline bool inventory(spritetype* S)
|
|
|
|
{
|
2020-11-29 12:54:58 +00:00
|
|
|
return !!(gs.actorinfo[S->picnum].flags & SFLAG_INVENTORY);
|
2020-07-06 16:08:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline void settileflag(int flag, const std::initializer_list<short>& types)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
for (auto val : types)
|
|
|
|
{
|
2020-11-29 12:54:58 +00:00
|
|
|
gs.tileinfo[val].flags |= flag;
|
2020-07-20 21:21:27 +00:00
|
|
|
}
|
2020-07-06 16:08:31 +00:00
|
|
|
}
|
|
|
|
|
2020-11-02 22:53:55 +00:00
|
|
|
inline bool wallswitchcheck(DDukeActor* s)
|
2020-07-06 16:08:31 +00:00
|
|
|
{
|
2021-04-15 17:21:43 +00:00
|
|
|
return !!(gs.tileinfo[s->s->picnum].flags & TFLAG_WALLSWITCH);
|
2020-07-06 16:08:31 +00:00
|
|
|
}
|
|
|
|
|
2020-07-06 20:23:18 +00:00
|
|
|
inline int checkcursectnums(int se)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
int i;
|
|
|
|
for(i=connecthead;i>=0;i=connectpoint2[i])
|
2021-04-15 17:21:43 +00:00
|
|
|
if(ps[i].GetActor() && ps[i].GetActor()->s->sectnum == se ) return i;
|
2020-07-20 21:21:27 +00:00
|
|
|
return -1;
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// These are from duke's sector.c
|
|
|
|
inline int ldist(const spritetype* s1, const spritetype* s2)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
int vx, vy;
|
|
|
|
vx = s1->x - s2->x;
|
|
|
|
vy = s1->y - s2->y;
|
|
|
|
return(FindDistance2D(vx, vy) + 1);
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline int dist(const spritetype* s1, const spritetype* s2)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
int vx, vy, vz;
|
|
|
|
vx = s1->x - s2->x;
|
|
|
|
vy = s1->y - s2->y;
|
|
|
|
vz = s1->z - s2->z;
|
2020-08-18 21:49:44 +00:00
|
|
|
return(FindDistance3D(vx, vy, vz));
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline bool isIn(int value, int first)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
return value == first;
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template<typename... Args>
|
|
|
|
bool isIn(int value, int first, Args... args)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
return value == first || isIn(value, args...);
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline bool isIn(int value, const std::initializer_list<int>& list)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
for (auto v : list) if (v == value) return true;
|
|
|
|
return false;
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// these are mainly here to avoid directly accessing the input data so that it can be more easily refactored later.
|
2020-08-27 20:19:24 +00:00
|
|
|
inline bool PlayerInput(int pl, ESyncBits bit)
|
|
|
|
{
|
2020-09-23 14:56:04 +00:00
|
|
|
return (!!((ps[pl].sync.actions) & bit));
|
2020-08-27 20:19:24 +00:00
|
|
|
}
|
|
|
|
|
2020-08-26 21:02:55 +00:00
|
|
|
inline ESyncBits PlayerInputBits(int pl, ESyncBits bits)
|
|
|
|
{
|
2020-09-23 14:56:04 +00:00
|
|
|
return (ps[pl].sync.actions & bits);
|
2020-08-26 21:02:55 +00:00
|
|
|
}
|
|
|
|
|
2020-08-27 22:03:35 +00:00
|
|
|
inline void PlayerSetInput(int pl, ESyncBits bit)
|
|
|
|
{
|
2020-09-23 14:56:04 +00:00
|
|
|
ps[pl].sync.actions |= bit;
|
2020-08-27 22:03:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-08-26 21:02:55 +00:00
|
|
|
inline int PlayerNewWeapon(int pl)
|
|
|
|
{
|
2021-07-17 12:42:58 +00:00
|
|
|
return ps[pl].sync.getNewWeapon();
|
2020-08-26 21:02:55 +00:00
|
|
|
}
|
|
|
|
|
2020-08-27 19:25:09 +00:00
|
|
|
inline void PlayerSetItemUsed(int pl, int num)
|
|
|
|
{
|
2020-09-23 14:56:04 +00:00
|
|
|
ps[pl].sync.setItemUsed(num - 1);
|
2020-08-27 19:25:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline bool PlayerUseItem(int pl, int num)
|
|
|
|
{
|
2020-09-23 14:56:04 +00:00
|
|
|
return ps[pl].sync.isItemUsed(num - 1);
|
2020-08-27 19:25:09 +00:00
|
|
|
}
|
|
|
|
|
2020-07-06 20:23:18 +00:00
|
|
|
inline int PlayerInputSideVel(int pl)
|
|
|
|
{
|
2020-09-23 14:56:04 +00:00
|
|
|
return ps[pl].sync.svel;
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline int PlayerInputForwardVel(int pl)
|
|
|
|
{
|
2020-09-23 14:56:04 +00:00
|
|
|
return ps[pl].sync.fvel;
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
2020-10-08 03:47:30 +00:00
|
|
|
inline float PlayerInputAngVel(int pl)
|
2020-07-06 20:23:18 +00:00
|
|
|
{
|
2020-10-08 03:47:30 +00:00
|
|
|
return ps[pl].sync.avel;
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
2021-05-02 19:56:31 +00:00
|
|
|
inline float GetPlayerHorizon(int pl)
|
2020-08-30 11:04:07 +00:00
|
|
|
{
|
2020-10-07 07:22:07 +00:00
|
|
|
return ps[pl].sync.horz;
|
2020-08-30 11:04:07 +00:00
|
|
|
}
|
|
|
|
|
2020-07-06 19:10:20 +00:00
|
|
|
inline void clearfriction()
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
for (int i = 0; i != -1; i = connectpoint2[i])
|
|
|
|
{
|
|
|
|
ps[i].fric.x = ps[i].fric.y = 0;
|
|
|
|
}
|
2020-07-06 19:10:20 +00:00
|
|
|
}
|
|
|
|
|
2020-07-06 21:24:35 +00:00
|
|
|
inline void SetPlayerPal(player_struct* p, PalEntry pe)
|
|
|
|
{
|
2020-07-20 21:21:27 +00:00
|
|
|
p->pals = pe;
|
2020-07-06 21:24:35 +00:00
|
|
|
}
|
2020-07-06 19:10:20 +00:00
|
|
|
|
2020-07-21 20:46:26 +00:00
|
|
|
inline bool playrunning()
|
|
|
|
{
|
|
|
|
return (paused == 0 || (paused == 1 && (ud.recstat == 2 || ud.multimode > 1)));
|
|
|
|
}
|
|
|
|
|
2021-01-01 22:32:19 +00:00
|
|
|
inline void doslopetilting(player_struct* p, double const scaleAdjust = 1)
|
2021-01-01 13:30:01 +00:00
|
|
|
{
|
2021-11-06 20:59:42 +00:00
|
|
|
bool const canslopetilt = p->on_ground && p->cursector()->lotag != ST_2_UNDERWATER && (p->cursector()->floorstat & 2);
|
2021-04-19 10:50:01 +00:00
|
|
|
p->horizon.calcviewpitch(p->pos.vec2, p->angle.ang, p->aim_mode == 0, canslopetilt, p->cursectnum, scaleAdjust);
|
2021-01-01 13:30:01 +00:00
|
|
|
}
|
|
|
|
|
2021-11-18 17:04:17 +00:00
|
|
|
inline DDukeActor* EGS(sectortype* whatsect, int s_x, int s_y, int s_z, int s_pn, int8_t s_s, int8_t s_xr, int8_t s_yr, int s_a, int s_ve, int s_zv, DDukeActor* s_ow, int8_t s_ss)
|
|
|
|
{
|
|
|
|
return EGS(sectnum(whatsect), s_x, s_y, s_z, s_pn, s_s, s_xr, s_yr, s_a, s_ve, s_zv, s_ow, s_ss);
|
|
|
|
}
|
2020-07-07 21:01:34 +00:00
|
|
|
|
2020-07-06 20:23:18 +00:00
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
2020-07-16 11:23:26 +00:00
|
|
|
inline void hud_draw(double x, double y, int tilenum, int shade, int orientation)
|
2020-07-06 20:23:18 +00:00
|
|
|
{
|
2021-11-06 20:59:42 +00:00
|
|
|
int p = ps[screenpeek].cursector()->floorpal;
|
2020-07-27 08:39:33 +00:00
|
|
|
hud_drawsprite(x, y, 65536, 0, tilenum, shade, p, 2 | orientation);
|
2020-07-06 20:23:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
END_DUKE_NS
|