mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-15 20:20:54 +00:00
- prepared folder for merging.
This commit is contained in:
parent
99958342a9
commit
0596078978
35 changed files with 1271 additions and 1923 deletions
|
@ -802,6 +802,7 @@ set (PCH_SOURCES
|
||||||
core/raze_sound.cpp
|
core/raze_sound.cpp
|
||||||
core/palette.cpp
|
core/palette.cpp
|
||||||
core/zcompile.cpp
|
core/zcompile.cpp
|
||||||
|
core/statusbar.cpp
|
||||||
|
|
||||||
core/2d/screentext.cpp
|
core/2d/screentext.cpp
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#define actors_c_
|
#define actors_c_
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
|
|
||||||
BEGIN_DUKE_NS
|
BEGIN_DUKE_NS
|
||||||
|
|
||||||
|
@ -1111,6 +1111,23 @@ static int P_Submerge(int, int, DukePlayer_t *, int, int);
|
||||||
static int P_Emerge(int, int, DukePlayer_t *, int, int);
|
static int P_Emerge(int, int, DukePlayer_t *, int, int);
|
||||||
static void P_FinishWaterChange(int, DukePlayer_t *, int, int, int);
|
static void P_FinishWaterChange(int, DukePlayer_t *, int, int, int);
|
||||||
|
|
||||||
|
static fix16_t P_GetQ16AngleDeltaForTic(DukePlayer_t const *pPlayer)
|
||||||
|
{
|
||||||
|
auto oldAngle = pPlayer->oq16ang;
|
||||||
|
auto newAngle = pPlayer->q16ang;
|
||||||
|
|
||||||
|
if (klabs(fix16_sub(oldAngle, newAngle)) < F16(1024))
|
||||||
|
return fix16_sub(newAngle, oldAngle);
|
||||||
|
|
||||||
|
if (newAngle > F16(1024))
|
||||||
|
newAngle = fix16_sub(newAngle, F16(2048));
|
||||||
|
|
||||||
|
if (oldAngle > F16(1024))
|
||||||
|
oldAngle = fix16_sub(oldAngle, F16(2048));
|
||||||
|
|
||||||
|
return fix16_sub(newAngle, oldAngle);
|
||||||
|
}
|
||||||
|
|
||||||
ACTOR_STATIC void G_MovePlayers(void)
|
ACTOR_STATIC void G_MovePlayers(void)
|
||||||
{
|
{
|
||||||
int spriteNum = headspritestat[STAT_PLAYER];
|
int spriteNum = headspritestat[STAT_PLAYER];
|
||||||
|
@ -1164,7 +1181,7 @@ ACTOR_STATIC void G_MovePlayers(void)
|
||||||
if (G_HaveActor(sprite[spriteNum].picnum))
|
if (G_HaveActor(sprite[spriteNum].picnum))
|
||||||
A_Execute(spriteNum, P_GetP(pSprite), otherPlayerDist);
|
A_Execute(spriteNum, P_GetP(pSprite), otherPlayerDist);
|
||||||
|
|
||||||
pPlayer->q16angvel = G_GetQ16AngleDelta(pPlayer->oq16ang, pPlayer->q16ang);
|
pPlayer->q16angvel = P_GetQ16AngleDeltaForTic(pPlayer);
|
||||||
pPlayer->oq16ang = pPlayer->q16ang;
|
pPlayer->oq16ang = pPlayer->q16ang;
|
||||||
pPlayer->oq16horiz = pPlayer->q16horiz;
|
pPlayer->oq16horiz = pPlayer->q16horiz;
|
||||||
pPlayer->oq16horizoff = pPlayer->q16horizoff;
|
pPlayer->oq16horizoff = pPlayer->q16horizoff;
|
||||||
|
@ -1211,7 +1228,7 @@ ACTOR_STATIC void G_MovePlayers(void)
|
||||||
|
|
||||||
if (pPlayer->wackedbyactor >= 0 && sprite[pPlayer->wackedbyactor].statnum < MAXSTATUS)
|
if (pPlayer->wackedbyactor >= 0 && sprite[pPlayer->wackedbyactor].statnum < MAXSTATUS)
|
||||||
{
|
{
|
||||||
pPlayer->q16ang += fix16_from_int(G_GetAngleDelta(fix16_to_int(pPlayer->q16ang),
|
pPlayer->q16ang += fix16_to_int(G_GetAngleDelta(pPlayer->q16ang,
|
||||||
getangle(sprite[pPlayer->wackedbyactor].x - pPlayer->pos.x,
|
getangle(sprite[pPlayer->wackedbyactor].x - pPlayer->pos.x,
|
||||||
sprite[pPlayer->wackedbyactor].y - pPlayer->pos.y))
|
sprite[pPlayer->wackedbyactor].y - pPlayer->pos.y))
|
||||||
>> 1);
|
>> 1);
|
||||||
|
|
|
@ -40,6 +40,7 @@ BEGIN_DUKE_NS
|
||||||
#define ACTOR_MAXFALLINGZVEL 6144
|
#define ACTOR_MAXFALLINGZVEL 6144
|
||||||
#define ACTOR_ONWATER_ADDZ (24<<8)
|
#define ACTOR_ONWATER_ADDZ (24<<8)
|
||||||
|
|
||||||
|
// KEEPINSYNC lunatic/con_lang.lua
|
||||||
#define STAT_DEFAULT 0
|
#define STAT_DEFAULT 0
|
||||||
#define STAT_ACTOR 1
|
#define STAT_ACTOR 1
|
||||||
#define STAT_ZOMBIEACTOR 2
|
#define STAT_ZOMBIEACTOR 2
|
||||||
|
@ -117,6 +118,8 @@ enum actionflags
|
||||||
AF_VIEWPOINT = 1u<<0u,
|
AF_VIEWPOINT = 1u<<0u,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Select an actor's actiontics and movflags locations depending on
|
||||||
|
// whether we compile the Lunatic build.
|
||||||
// <spr>: sprite pointer
|
// <spr>: sprite pointer
|
||||||
// <a>: actor_t pointer
|
// <a>: actor_t pointer
|
||||||
# define AC_ACTIONTICS(spr, a) ((spr)->lotag)
|
# define AC_ACTIONTICS(spr, a) ((spr)->lotag)
|
||||||
|
@ -176,6 +179,7 @@ typedef struct
|
||||||
} tiledata_t;
|
} tiledata_t;
|
||||||
|
|
||||||
|
|
||||||
|
// KEEPINSYNC lunatic/con_lang.lua
|
||||||
enum sflags_t
|
enum sflags_t
|
||||||
{
|
{
|
||||||
SFLAG_SHADOW = 0x00000001,
|
SFLAG_SHADOW = 0x00000001,
|
||||||
|
|
|
@ -24,7 +24,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "baselayer.h"
|
#include "baselayer.h"
|
||||||
#include "baselayer.h"
|
#include "baselayer.h"
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "animlib.h"
|
#include "animlib.h"
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "cmdlib.h"
|
#include "cmdlib.h"
|
||||||
|
@ -480,7 +480,7 @@ int32_t Anim_Play(const char *fn)
|
||||||
|
|
||||||
{
|
{
|
||||||
AnimTextures animtex;
|
AnimTextures animtex;
|
||||||
animtex.SetSize(320, 200);
|
animtex.SetSize(AnimTexture::Paletted, 320, 200);
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
@ -562,7 +562,6 @@ int32_t Anim_Play(const char *fn)
|
||||||
|
|
||||||
end_anim_restore_gl:
|
end_anim_restore_gl:
|
||||||
gl_texture_filter = ogltexfiltermode;
|
gl_texture_filter = ogltexfiltermode;
|
||||||
gltexapplyprops();
|
|
||||||
end_anim:
|
end_anim:
|
||||||
inputState.ClearAllInput();
|
inputState.ClearAllInput();
|
||||||
anim->animbuf = nullptr;
|
anim->animbuf = nullptr;
|
||||||
|
|
|
@ -25,7 +25,8 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
BEGIN_DUKE_NS
|
BEGIN_DUKE_NS
|
||||||
|
|
||||||
struct animsound_t {
|
struct animsound_t
|
||||||
|
{
|
||||||
uint16_t frame = 0;
|
uint16_t frame = 0;
|
||||||
int16_t sound = 0;
|
int16_t sound = 0;
|
||||||
};
|
};
|
||||||
|
|
|
@ -22,7 +22,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "osdcmds.h"
|
#include "osdcmds.h"
|
||||||
#include "cheats.h"
|
#include "cheats.h"
|
||||||
#include "mapinfo.h"
|
#include "mapinfo.h"
|
||||||
|
@ -428,9 +428,9 @@ void G_DoCheats(void)
|
||||||
{
|
{
|
||||||
case CHEAT_WEAPONS:
|
case CHEAT_WEAPONS:
|
||||||
{
|
{
|
||||||
int const weaponLimit = (VOLUMEONE) ? 6 : 0;
|
int const weaponLimit = (VOLUMEONE) ? SHRINKER_WEAPON : MAX_WEAPONS;
|
||||||
|
|
||||||
for (bssize_t weaponNum = PISTOL_WEAPON; weaponNum < MAX_WEAPONS-weaponLimit; weaponNum++)
|
for (bssize_t weaponNum = PISTOL_WEAPON; weaponNum < weaponLimit; weaponNum++)
|
||||||
{
|
{
|
||||||
P_AddAmmo(pPlayer, weaponNum, pPlayer->max_ammo_amount[weaponNum]);
|
P_AddAmmo(pPlayer, weaponNum, pPlayer->max_ammo_amount[weaponNum]);
|
||||||
pPlayer->gotweapon |= (1<<weaponNum);
|
pPlayer->gotweapon |= (1<<weaponNum);
|
||||||
|
@ -565,12 +565,12 @@ void G_DoCheats(void)
|
||||||
|
|
||||||
case CHEAT_STUFF:
|
case CHEAT_STUFF:
|
||||||
{
|
{
|
||||||
int const weaponLimit = (VOLUMEONE) ? 6 : 0;
|
int const weaponLimit = (VOLUMEONE) ? SHRINKER_WEAPON : MAX_WEAPONS;
|
||||||
|
|
||||||
for (bssize_t weaponNum = PISTOL_WEAPON; weaponNum < MAX_WEAPONS-weaponLimit; weaponNum++)
|
for (bssize_t weaponNum = PISTOL_WEAPON; weaponNum < weaponLimit; weaponNum++)
|
||||||
pPlayer->gotweapon |= (1<<weaponNum);
|
pPlayer->gotweapon |= (1 << weaponNum);
|
||||||
|
|
||||||
for (bssize_t weaponNum = PISTOL_WEAPON; weaponNum < MAX_WEAPONS-weaponLimit; weaponNum++)
|
for (bssize_t weaponNum = PISTOL_WEAPON; weaponNum < weaponLimit; weaponNum++)
|
||||||
P_AddAmmo(pPlayer, weaponNum, pPlayer->max_ammo_amount[weaponNum]);
|
P_AddAmmo(pPlayer, weaponNum, pPlayer->max_ammo_amount[weaponNum]);
|
||||||
|
|
||||||
if (RRRA)
|
if (RRRA)
|
||||||
|
|
|
@ -22,7 +22,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "demo.h"
|
#include "demo.h"
|
||||||
#include "screens.h"
|
#include "screens.h"
|
||||||
#include "baselayer.h"
|
#include "baselayer.h"
|
||||||
|
|
|
@ -22,7 +22,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "osdcmds.h"
|
#include "osdcmds.h"
|
||||||
#include "baselayer.h"
|
#include "baselayer.h"
|
||||||
#include "cmdline.h"
|
#include "cmdline.h"
|
||||||
|
@ -42,7 +42,7 @@ int32_t CONFIG_ReadSetup(void)
|
||||||
ud.camera_time = 0;//4;
|
ud.camera_time = 0;//4;
|
||||||
|
|
||||||
ud.screen_tilting = 1;
|
ud.screen_tilting = 1;
|
||||||
ud.statusbarflags = STATUSBAR_NOSHRINK;
|
ud.statusbarflags = 0;// STATUSBAR_NOSHRINK;
|
||||||
playerteam = 0;
|
playerteam = 0;
|
||||||
ud.angleinterpolation = 0;
|
ud.angleinterpolation = 0;
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
#include "cheats.h"
|
#include "cheats.h"
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "demo.h"
|
#include "demo.h"
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
|
|
||||||
#include "menus.h"
|
#include "menus.h"
|
||||||
#include "osdcmds.h"
|
#include "osdcmds.h"
|
||||||
|
@ -326,7 +326,7 @@ void Menu_DHLeaonardHeadDisplay(vec2_t pos)
|
||||||
//
|
//
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
|
||||||
class Duke3dListMenu : public DListMenu
|
class DukeListMenu : public DListMenu
|
||||||
{
|
{
|
||||||
using Super = DListMenu;
|
using Super = DListMenu;
|
||||||
protected:
|
protected:
|
||||||
|
@ -369,17 +369,17 @@ protected:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class Duke3dMainMenu : public Duke3dListMenu
|
class DukeMainMenu : public DukeListMenu
|
||||||
{
|
{
|
||||||
virtual void Init(DMenu* parent = NULL, FListMenuDescriptor* desc = NULL) override
|
virtual void Init(DMenu* parent = NULL, FListMenuDescriptor* desc = NULL) override
|
||||||
{
|
{
|
||||||
Duke3dListMenu::Init(parent, desc);
|
DukeListMenu::Init(parent, desc);
|
||||||
Menu_DHLeaonardHeadReset();
|
Menu_DHLeaonardHeadReset();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PreDraw() override
|
void PreDraw() override
|
||||||
{
|
{
|
||||||
Duke3dListMenu::PreDraw();
|
DukeListMenu::PreDraw();
|
||||||
if (DEER)
|
if (DEER)
|
||||||
{
|
{
|
||||||
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
||||||
|
@ -405,11 +405,11 @@ class Duke3dMainMenu : public Duke3dListMenu
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
class Duke3dHuntMenu : public Duke3dListMenu
|
class DukeHuntMenu : public DukeListMenu
|
||||||
{
|
{
|
||||||
void PreDraw() override
|
void PreDraw() override
|
||||||
{
|
{
|
||||||
Duke3dListMenu::PreDraw();
|
DukeListMenu::PreDraw();
|
||||||
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
||||||
int t1, t2;
|
int t1, t2;
|
||||||
short ang;
|
short ang;
|
||||||
|
@ -443,11 +443,11 @@ class Duke3dHuntMenu : public Duke3dListMenu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class Duke3dTargetMenu : public Duke3dListMenu
|
class DukeTargetMenu : public DukeListMenu
|
||||||
{
|
{
|
||||||
void PreDraw() override
|
void PreDraw() override
|
||||||
{
|
{
|
||||||
Duke3dListMenu::PreDraw();
|
DukeListMenu::PreDraw();
|
||||||
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
||||||
int t1, t2;
|
int t1, t2;
|
||||||
short ang;
|
short ang;
|
||||||
|
@ -472,11 +472,11 @@ class Duke3dTargetMenu : public Duke3dListMenu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class Duke3dWeaponMenu : public Duke3dListMenu
|
class DukeWeaponMenu : public DukeListMenu
|
||||||
{
|
{
|
||||||
void PreDraw() override
|
void PreDraw() override
|
||||||
{
|
{
|
||||||
Duke3dListMenu::PreDraw();
|
DukeListMenu::PreDraw();
|
||||||
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
||||||
int t1, t2;
|
int t1, t2;
|
||||||
switch (mDesc->mSelectedItem)
|
switch (mDesc->mSelectedItem)
|
||||||
|
@ -508,11 +508,11 @@ class Duke3dWeaponMenu : public Duke3dListMenu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class Duke3dTrophiesMenu : public Duke3dListMenu
|
class DukeTrophiesMenu : public DukeListMenu
|
||||||
{
|
{
|
||||||
void PreDraw() override
|
void PreDraw() override
|
||||||
{
|
{
|
||||||
Duke3dListMenu::PreDraw();
|
DukeListMenu::PreDraw();
|
||||||
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
vec2_t forigin = { int(origin.X * 65536), int(origin.Y * 65536) };
|
||||||
if (g_player[myconnectindex].ps->gm & MODE_GAME)
|
if (g_player[myconnectindex].ps->gm & MODE_GAME)
|
||||||
{
|
{
|
||||||
|
@ -580,7 +580,7 @@ void GameInterface::DrawNativeMenuText(int fontnum, int state, double xpos, doub
|
||||||
|
|
||||||
void GameInterface::MenuOpened()
|
void GameInterface::MenuOpened()
|
||||||
{
|
{
|
||||||
S_PauseSound(true, false);
|
S_PauseSounds(true);
|
||||||
if ((!g_netServer && ud.multimode < 2))
|
if ((!g_netServer && ud.multimode < 2))
|
||||||
{
|
{
|
||||||
ready2send = 0;
|
ready2send = 0;
|
||||||
|
@ -646,7 +646,7 @@ void GameInterface::MenuClosed()
|
||||||
}
|
}
|
||||||
|
|
||||||
G_UpdateScreenArea();
|
G_UpdateScreenArea();
|
||||||
S_ResumeSound(false);
|
S_PauseSounds(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -775,13 +775,13 @@ END_DUKE_NS
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
static TMenuClassDescriptor<Duke3d::Duke3dMainMenu> _mm("Duke3d.MainMenu");
|
static TMenuClassDescriptor<Duke3d::DukeMainMenu> _mm("Duke.MainMenu");
|
||||||
static TMenuClassDescriptor<Duke3d::Duke3dListMenu> _lm("Duke3d.ListMenu");
|
static TMenuClassDescriptor<Duke3d::DukeListMenu> _lm("Duke.ListMenu");
|
||||||
static TMenuClassDescriptor<Duke3d::Duke3dHuntMenu> _dhm("Duke3d.HuntMenu");
|
static TMenuClassDescriptor<Duke3d::DukeHuntMenu> _dhm("Duke.HuntMenu");
|
||||||
static TMenuClassDescriptor<Duke3d::Duke3dTargetMenu> _dtm("Duke3d.TargetMenu");
|
static TMenuClassDescriptor<Duke3d::DukeTargetMenu> _dtm("Duke.TargetMenu");
|
||||||
static TMenuClassDescriptor<Duke3d::Duke3dWeaponMenu> _dwm("Duke3d.WeaponMenu");
|
static TMenuClassDescriptor<Duke3d::DukeWeaponMenu> _dwm("Duke.WeaponMenu");
|
||||||
static TMenuClassDescriptor<Duke3d::Duke3dTrophiesMenu> _dttm("Duke3d.TrophiesMenu");
|
static TMenuClassDescriptor<Duke3d::DukeTrophiesMenu> _dttm("Duke.TrophiesMenu");
|
||||||
static TMenuClassDescriptor<DImageScrollerMenu> _ism("Duke3d.ImageScrollerMenu"); // does not implement a new class, we only need the descriptor.
|
static TMenuClassDescriptor<DImageScrollerMenu> _ism("Duke.ImageScrollerMenu"); // does not implement a new class, we only need the descriptor.
|
||||||
|
|
||||||
void RegisterDuke3dMenus()
|
void RegisterDuke3dMenus()
|
||||||
{
|
{
|
||||||
|
|
|
@ -23,7 +23,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "demo.h"
|
#include "demo.h"
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
|
|
||||||
#include "menus.h"
|
#include "menus.h"
|
||||||
#include "savegame.h"
|
#include "savegame.h"
|
||||||
|
@ -120,7 +120,7 @@ static int32_t G_OpenDemoRead(int32_t g_whichDemo) // 0 = mine
|
||||||
|
|
||||||
gFullMap = false;
|
gFullMap = false;
|
||||||
ud.god = ud.cashman = ud.eog = 0;
|
ud.god = ud.cashman = ud.eog = 0;
|
||||||
ud.noclip = ud.scrollmode = ud.overhead_on = 0; //= paused = 0;
|
ud.noclip = ud.scrollmode = ud.overhead_on = 0; //= ud.pause_on = 0;
|
||||||
|
|
||||||
totalclock = ototalclock = lockclock = 0;
|
totalclock = ototalclock = lockclock = 0;
|
||||||
|
|
||||||
|
@ -591,7 +591,7 @@ RECHECK:
|
||||||
Demo_FinishProfile();
|
Demo_FinishProfile();
|
||||||
|
|
||||||
while (totalclock >= (lockclock+TICSPERFRAME)
|
while (totalclock >= (lockclock+TICSPERFRAME)
|
||||||
// || (ud.reccnt > REALGAMETICSPERSEC*2 && paused)
|
// || (ud.reccnt > REALGAMETICSPERSEC*2 && ud.pause_on)
|
||||||
|| (g_demo_goalCnt>0 && g_demo_cnt<g_demo_goalCnt))
|
|| (g_demo_goalCnt>0 && g_demo_cnt<g_demo_goalCnt))
|
||||||
{
|
{
|
||||||
if (ud.reccnt<=0)
|
if (ud.reccnt<=0)
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#define EDUKE32_EVENTS_DEFS_H_
|
#define EDUKE32_EVENTS_DEFS_H_
|
||||||
|
|
||||||
// the order of these can't be changed or else compatibility with EDuke 2.0 mods will break
|
// the order of these can't be changed or else compatibility with EDuke 2.0 mods will break
|
||||||
|
// KEEPINSYNC with EventNames[] and lunatic/con_lang.lua
|
||||||
enum GameEvent_t {
|
enum GameEvent_t {
|
||||||
EVENT_INIT, // 0
|
EVENT_INIT, // 0
|
||||||
EVENT_ENTERLEVEL,
|
EVENT_ENTERLEVEL,
|
||||||
|
|
|
@ -24,7 +24,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#define game_c_
|
#define game_c_
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "baselayer.h"
|
#include "baselayer.h"
|
||||||
#include "osdcmds.h"
|
#include "osdcmds.h"
|
||||||
|
@ -49,7 +49,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
#include "mapinfo.h"
|
#include "mapinfo.h"
|
||||||
#include "v_video.h"
|
#include "v_video.h"
|
||||||
#include "glbackend/glbackend.h"
|
#include "glbackend/glbackend.h"
|
||||||
#include "playmve.h"
|
|
||||||
|
|
||||||
// Uncomment to prevent anything except mirrors from drawing. It is sensible to
|
// Uncomment to prevent anything except mirrors from drawing. It is sensible to
|
||||||
// also uncomment ENGINE_CLEAR_SCREEN in build/src/engine_priv.h.
|
// also uncomment ENGINE_CLEAR_SCREEN in build/src/engine_priv.h.
|
||||||
|
@ -833,7 +832,7 @@ void G_DrawRooms(int32_t playerNum, int32_t smoothRatio)
|
||||||
|
|
||||||
if (pub > 0 || videoGetRenderMode() >= REND_POLYMOST) // JBF 20040101: redraw background always
|
if (pub > 0 || videoGetRenderMode() >= REND_POLYMOST) // JBF 20040101: redraw background always
|
||||||
{
|
{
|
||||||
videoClearScreen(0);
|
//videoClearScreen(0);
|
||||||
#ifndef EDUKE32_TOUCH_DEVICES
|
#ifndef EDUKE32_TOUCH_DEVICES
|
||||||
if (ud.screen_size >= 8)
|
if (ud.screen_size >= 8)
|
||||||
#endif
|
#endif
|
||||||
|
@ -850,7 +849,7 @@ void G_DrawRooms(int32_t playerNum, int32_t smoothRatio)
|
||||||
videoSetCorrectedAspect();
|
videoSetCorrectedAspect();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (paused || pPlayer->on_crane > -1)
|
if (ud.pause_on || pPlayer->on_crane > -1)
|
||||||
smoothRatio = 65536;
|
smoothRatio = 65536;
|
||||||
else
|
else
|
||||||
smoothRatio = calc_smoothratio(totalclock, ototalclock);
|
smoothRatio = calc_smoothratio(totalclock, ototalclock);
|
||||||
|
@ -918,14 +917,14 @@ void G_DrawRooms(int32_t playerNum, int32_t smoothRatio)
|
||||||
))
|
))
|
||||||
{
|
{
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
renderSetRollAngle(fix16_to_float(pPlayer->q16rotscrnang));
|
renderSetRollAngle(pPlayer->orotscrnang + mulscale16(((pPlayer->rotscrnang - pPlayer->orotscrnang + 1024)&2047)-1024, smoothRatio));
|
||||||
#endif
|
#endif
|
||||||
pPlayer->oq16rotscrnang = pPlayer->q16rotscrnang;
|
pPlayer->orotscrnang = pPlayer->rotscrnang;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (RRRA && pPlayer->drug_mode > 0)
|
if (RRRA && pPlayer->drug_mode > 0)
|
||||||
{
|
{
|
||||||
while (pPlayer->drug_timer < totalclock && !(pPlayer->gm & MODE_MENU) && !paused && !System_WantGuiCapture())
|
while (pPlayer->drug_timer < totalclock && !(pPlayer->gm & MODE_MENU) && !ud.pause_on && !System_WantGuiCapture())
|
||||||
{
|
{
|
||||||
int aspect;
|
int aspect;
|
||||||
if (pPlayer->drug_stat[0] == 0)
|
if (pPlayer->drug_stat[0] == 0)
|
||||||
|
@ -1016,7 +1015,7 @@ void G_DrawRooms(int32_t playerNum, int32_t smoothRatio)
|
||||||
omypos.z + mulscale16(mypos.z - omypos.z, smoothRatio) };
|
omypos.z + mulscale16(mypos.z - omypos.z, smoothRatio) };
|
||||||
|
|
||||||
CAMERA(pos) = camVect;
|
CAMERA(pos) = camVect;
|
||||||
CAMERA(q16ang) = myang + pPlayer->q16look_ang;
|
CAMERA(q16ang) = myang + fix16_from_int(pPlayer->look_ang);
|
||||||
CAMERA(q16horiz) = myhoriz + myhorizoff;
|
CAMERA(q16horiz) = myhoriz + myhorizoff;
|
||||||
CAMERA(sect) = mycursectnum;
|
CAMERA(sect) = mycursectnum;
|
||||||
}
|
}
|
||||||
|
@ -1027,21 +1026,9 @@ void G_DrawRooms(int32_t playerNum, int32_t smoothRatio)
|
||||||
pPlayer->opos.z + mulscale16(pPlayer->pos.z - pPlayer->opos.z, smoothRatio) };
|
pPlayer->opos.z + mulscale16(pPlayer->pos.z - pPlayer->opos.z, smoothRatio) };
|
||||||
|
|
||||||
CAMERA(pos) = camVect;
|
CAMERA(pos) = camVect;
|
||||||
|
CAMERA(q16ang) = pPlayer->q16ang + fix16_from_int(pPlayer->look_ang);
|
||||||
if (pPlayer->wackedbyactor >= 0)
|
|
||||||
{
|
|
||||||
CAMERA(q16ang) = pPlayer->oq16ang
|
|
||||||
+ mulscale16(((pPlayer->q16ang + F16(1024) - pPlayer->oq16ang) & 0x7FFFFFF) - F16(1024), smoothRatio)
|
|
||||||
+ pPlayer->q16look_ang;
|
|
||||||
CAMERA(q16horiz) = pPlayer->oq16horiz + pPlayer->oq16horizoff
|
|
||||||
+ mulscale16((pPlayer->q16horiz + pPlayer->q16horizoff - pPlayer->oq16horiz - pPlayer->oq16horizoff), smoothRatio);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
CAMERA(q16ang) = pPlayer->q16ang + pPlayer->q16look_ang;
|
|
||||||
CAMERA(q16horiz) = pPlayer->q16horiz + pPlayer->q16horizoff;
|
CAMERA(q16horiz) = pPlayer->q16horiz + pPlayer->q16horizoff;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (cl_viewbob)
|
if (cl_viewbob)
|
||||||
{
|
{
|
||||||
|
@ -1070,7 +1057,7 @@ void G_DrawRooms(int32_t playerNum, int32_t smoothRatio)
|
||||||
|
|
||||||
// looking through viewscreen
|
// looking through viewscreen
|
||||||
CAMERA(pos) = camVect;
|
CAMERA(pos) = camVect;
|
||||||
CAMERA(q16ang) = pPlayer->q16ang + pPlayer->q16look_ang;
|
CAMERA(q16ang) = pPlayer->q16ang + fix16_from_int(pPlayer->look_ang);
|
||||||
CAMERA(q16horiz) = fix16_from_int(100 + sprite[pPlayer->newowner].shade);
|
CAMERA(q16horiz) = fix16_from_int(100 + sprite[pPlayer->newowner].shade);
|
||||||
CAMERA(sect) = sprite[pPlayer->newowner].sectnum;
|
CAMERA(sect) = sprite[pPlayer->newowner].sectnum;
|
||||||
}
|
}
|
||||||
|
@ -3180,7 +3167,6 @@ rr_badguy:
|
||||||
}
|
}
|
||||||
else changespritestat(newSprite, STAT_ZOMBIEACTOR);
|
else changespritestat(newSprite, STAT_ZOMBIEACTOR);
|
||||||
|
|
||||||
if (RR && spriteNum >= 0)
|
|
||||||
pSprite->shade = sprite[spriteNum].shade;
|
pSprite->shade = sprite[spriteNum].shade;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5026,7 +5012,7 @@ default_case1:
|
||||||
spritesortcnt++;
|
spritesortcnt++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_player[playerNum].input->extbits & (1 << 7) && !paused && spritesortcnt < maxspritesonscreen)
|
if (g_player[playerNum].input->extbits & (1 << 7) && !ud.pause_on && spritesortcnt < maxspritesonscreen)
|
||||||
{
|
{
|
||||||
tspritetype *const playerTyping = t;
|
tspritetype *const playerTyping = t;
|
||||||
|
|
||||||
|
@ -5280,11 +5266,11 @@ default_case2:
|
||||||
if ((unsigned)scrofs_action + ACTION_VIEWTYPE >= (unsigned)g_scriptSize)
|
if ((unsigned)scrofs_action + ACTION_VIEWTYPE >= (unsigned)g_scriptSize)
|
||||||
goto skip;
|
goto skip;
|
||||||
|
|
||||||
l = apScript[scrofs_action + ACTION_VIEWTYPE];
|
int viewtype = apScript[scrofs_action + ACTION_VIEWTYPE];
|
||||||
uint16_t const action_flags = apScript[scrofs_action + ACTION_FLAGS];
|
uint16_t const action_flags = apScript[scrofs_action + ACTION_FLAGS];
|
||||||
|
|
||||||
int const invertp = l < 0;
|
int const invertp = viewtype < 0;
|
||||||
l = klabs(l);
|
l = klabs(viewtype);
|
||||||
|
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
if (videoGetRenderMode() >= REND_POLYMOST && hw_models && md_tilehasmodel(pSprite->picnum,t->pal) >= 0 && !(spriteext[i].flags&SPREXT_NOTMD))
|
if (videoGetRenderMode() >= REND_POLYMOST && hw_models && md_tilehasmodel(pSprite->picnum,t->pal) >= 0 && !(spriteext[i].flags&SPREXT_NOTMD))
|
||||||
|
@ -6598,12 +6584,6 @@ static inline void G_CheckGametype(void)
|
||||||
ud.m_respawn_items = ud.m_respawn_inventory = 1;
|
ud.m_respawn_items = ud.m_respawn_inventory = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void G_PostLoadPalette(void)
|
|
||||||
{
|
|
||||||
//if (!(duke3d_globalflags & DUKE3D_NO_HARDCODED_FOGPALS))
|
|
||||||
// paletteSetupDefaultFog();
|
|
||||||
}
|
|
||||||
|
|
||||||
#define SETFLAG(Tilenum, Flag) g_tile[Tilenum].flags |= Flag
|
#define SETFLAG(Tilenum, Flag) g_tile[Tilenum].flags |= Flag
|
||||||
|
|
||||||
// Has to be after setting the dynamic names (e.g. SHARK).
|
// Has to be after setting the dynamic names (e.g. SHARK).
|
||||||
|
@ -7123,8 +7103,6 @@ int GameInterface::app_main()
|
||||||
|
|
||||||
enginePostInit();
|
enginePostInit();
|
||||||
|
|
||||||
G_PostLoadPalette();
|
|
||||||
|
|
||||||
tileDelete(MIRROR);
|
tileDelete(MIRROR);
|
||||||
|
|
||||||
skiptile = W_FORCEFIELD + 1;
|
skiptile = W_FORCEFIELD + 1;
|
||||||
|
@ -7297,17 +7275,10 @@ MAIN_LOOP_RESTART:
|
||||||
char gameUpdate = false;
|
char gameUpdate = false;
|
||||||
double const gameUpdateStartTime = timerGetHiTicks();
|
double const gameUpdateStartTime = timerGetHiTicks();
|
||||||
|
|
||||||
updatePauseStatus();
|
|
||||||
|
|
||||||
if (paused)
|
|
||||||
{
|
|
||||||
ototalclock = totalclock - TICSPERFRAME;
|
|
||||||
buttonMap.ResetButtonStates();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
while (((g_netClient || g_netServer) || !(g_player[myconnectindex].ps->gm & (MODE_MENU|MODE_DEMO))) && (int)(totalclock - ototalclock) >= TICSPERFRAME)
|
while (((g_netClient || g_netServer) || !(g_player[myconnectindex].ps->gm & (MODE_MENU|MODE_DEMO))) && (int)(totalclock - ototalclock) >= TICSPERFRAME)
|
||||||
{
|
{
|
||||||
|
ototalclock += TICSPERFRAME;
|
||||||
|
|
||||||
if (RRRA && g_player[myconnectindex].ps->on_motorcycle)
|
if (RRRA && g_player[myconnectindex].ps->on_motorcycle)
|
||||||
P_GetInputMotorcycle(myconnectindex);
|
P_GetInputMotorcycle(myconnectindex);
|
||||||
else if (RRRA && g_player[myconnectindex].ps->on_boat)
|
else if (RRRA && g_player[myconnectindex].ps->on_boat)
|
||||||
|
@ -7331,9 +7302,7 @@ MAIN_LOOP_RESTART:
|
||||||
|
|
||||||
g_player[myconnectindex].movefifoend++;
|
g_player[myconnectindex].movefifoend++;
|
||||||
|
|
||||||
ototalclock += TICSPERFRAME;
|
if (((!System_WantGuiCapture() && (g_player[myconnectindex].ps->gm&MODE_MENU) != MODE_MENU) || ud.recstat == 2 || (g_netServer || ud.multimode > 1)) &&
|
||||||
|
|
||||||
if (paused == 0 && (!System_WantGuiCapture() || ud.recstat == 2 || (g_netServer || ud.multimode > 1)) &&
|
|
||||||
(g_player[myconnectindex].ps->gm&MODE_GAME))
|
(g_player[myconnectindex].ps->gm&MODE_GAME))
|
||||||
{
|
{
|
||||||
G_MoveLoop();
|
G_MoveLoop();
|
||||||
|
@ -7347,7 +7316,6 @@ MAIN_LOOP_RESTART:
|
||||||
g_gameUpdateAvgTime = ((GAMEUPDATEAVGTIMENUMSAMPLES-1.f)*g_gameUpdateAvgTime+g_gameUpdateTime)/((float) GAMEUPDATEAVGTIMENUMSAMPLES);
|
g_gameUpdateAvgTime = ((GAMEUPDATEAVGTIMENUMSAMPLES-1.f)*g_gameUpdateAvgTime+g_gameUpdateTime)/((float) GAMEUPDATEAVGTIMENUMSAMPLES);
|
||||||
|
|
||||||
G_DoCheats();
|
G_DoCheats();
|
||||||
}
|
|
||||||
|
|
||||||
if (g_player[myconnectindex].ps->gm & (MODE_EOL|MODE_RESTART))
|
if (g_player[myconnectindex].ps->gm & (MODE_EOL|MODE_RESTART))
|
||||||
{
|
{
|
||||||
|
@ -7531,8 +7499,11 @@ int G_DoMoveThings(void)
|
||||||
everyothertime++;
|
everyothertime++;
|
||||||
if (g_earthquakeTime > 0) g_earthquakeTime--;
|
if (g_earthquakeTime > 0) g_earthquakeTime--;
|
||||||
|
|
||||||
|
if (ud.pause_on == 0)
|
||||||
|
{
|
||||||
g_globalRandom = krand2();
|
g_globalRandom = krand2();
|
||||||
A_MoveDummyPlayers();//ST 13
|
A_MoveDummyPlayers();//ST 13
|
||||||
|
}
|
||||||
|
|
||||||
for (bssize_t TRAVERSE_CONNECT(i))
|
for (bssize_t TRAVERSE_CONNECT(i))
|
||||||
{
|
{
|
||||||
|
@ -7554,11 +7525,15 @@ int G_DoMoveThings(void)
|
||||||
if (!DEER)
|
if (!DEER)
|
||||||
P_HandleSharedKeys(i);
|
P_HandleSharedKeys(i);
|
||||||
|
|
||||||
|
if (ud.pause_on == 0)
|
||||||
|
{
|
||||||
P_ProcessInput(i);
|
P_ProcessInput(i);
|
||||||
if (!DEER)
|
if (!DEER)
|
||||||
P_CheckSectors(i);
|
P_CheckSectors(i);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ud.pause_on == 0)
|
||||||
G_MoveWorld();
|
G_MoveWorld();
|
||||||
|
|
||||||
Net_CorrectPrediction();
|
Net_CorrectPrediction();
|
||||||
|
|
|
@ -27,7 +27,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "fix16.h"
|
#include "fix16.h"
|
||||||
#include "gamedefs.h"
|
|
||||||
#include "gamedef.h"
|
#include "gamedef.h"
|
||||||
#include "net.h"
|
#include "net.h"
|
||||||
#include "mmulti.h"
|
#include "mmulti.h"
|
||||||
|
@ -123,6 +122,8 @@ void A_DeleteSprite(int spriteNum);
|
||||||
|
|
||||||
#define MAX_RETURN_VALUES 6
|
#define MAX_RETURN_VALUES 6
|
||||||
|
|
||||||
|
// KEEPINSYNC lunatic/_defs_game.lua
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
vec3_t camerapos;
|
vec3_t camerapos;
|
||||||
int32_t const_visibility,uw_framerate;
|
int32_t const_visibility,uw_framerate;
|
||||||
|
@ -312,7 +313,7 @@ static inline int32_t calc_smoothratio(ClockTicks totalclk, ClockTicks ototalclk
|
||||||
if (!(((!g_netServer && ud.multimode < 2) && ((g_player[myconnectindex].ps->gm & MODE_MENU) == 0)) ||
|
if (!(((!g_netServer && ud.multimode < 2) && ((g_player[myconnectindex].ps->gm & MODE_MENU) == 0)) ||
|
||||||
(g_netServer || ud.multimode > 1) ||
|
(g_netServer || ud.multimode > 1) ||
|
||||||
ud.recstat == 2) ||
|
ud.recstat == 2) ||
|
||||||
paused)
|
ud.pause_on)
|
||||||
{
|
{
|
||||||
return 65536;
|
return 65536;
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "namesdyn.h"
|
#include "namesdyn.h"
|
||||||
#include "gamedef.h"
|
#include "gamedef.h"
|
||||||
#include "gameexec.h"
|
#include "gameexec.h"
|
||||||
|
|
|
@ -348,6 +348,7 @@ enum ScriptKeywords_t
|
||||||
CON_IFPUPWIND, // 166
|
CON_IFPUPWIND, // 166
|
||||||
CON_END
|
CON_END
|
||||||
};
|
};
|
||||||
|
// KEEPINSYNC with the keyword list in lunatic/con_lang.lua
|
||||||
|
|
||||||
END_DUKE_NS
|
END_DUKE_NS
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
|
|
||||||
#include "anim.h"
|
#include "anim.h"
|
||||||
|
|
||||||
|
@ -261,8 +261,8 @@ GAMEEXEC_STATIC GAMEEXEC_INLINE void P_ForceAngle(DukePlayer_t *pPlayer)
|
||||||
|
|
||||||
pPlayer->q16horiz += F16(64);
|
pPlayer->q16horiz += F16(64);
|
||||||
pPlayer->return_to_center = 9;
|
pPlayer->return_to_center = 9;
|
||||||
pPlayer->q16rotscrnang = fix16_from_int(nAngle >> 1);
|
pPlayer->rotscrnang = nAngle >> 1;
|
||||||
pPlayer->q16look_ang = pPlayer->q16rotscrnang;
|
pPlayer->look_ang = pPlayer->rotscrnang;
|
||||||
}
|
}
|
||||||
|
|
||||||
// wow, this function sucks
|
// wow, this function sucks
|
||||||
|
@ -492,20 +492,6 @@ int32_t __fastcall G_GetAngleDelta(int32_t currAngle, int32_t newAngle)
|
||||||
return newAngle-currAngle;
|
return newAngle-currAngle;
|
||||||
}
|
}
|
||||||
|
|
||||||
fix16_t __fastcall G_GetQ16AngleDelta(fix16_t oldAngle, fix16_t newAngle)
|
|
||||||
{
|
|
||||||
if (fix16_abs(fix16_sub(oldAngle, newAngle)) < fix16_from_int(1024))
|
|
||||||
return fix16_sub(newAngle, oldAngle);
|
|
||||||
|
|
||||||
if (newAngle > fix16_from_int(1024))
|
|
||||||
newAngle = fix16_sub(newAngle, fix16_from_int(2048));
|
|
||||||
|
|
||||||
if (oldAngle > fix16_from_int(1024))
|
|
||||||
oldAngle = fix16_sub(oldAngle, fix16_from_int(2048));
|
|
||||||
|
|
||||||
return fix16_sub(newAngle, oldAngle);
|
|
||||||
}
|
|
||||||
|
|
||||||
GAMEEXEC_STATIC void VM_AlterAng(int32_t const moveFlags)
|
GAMEEXEC_STATIC void VM_AlterAng(int32_t const moveFlags)
|
||||||
{
|
{
|
||||||
int const elapsedTics = (AC_COUNT(vm.pData))&31;
|
int const elapsedTics = (AC_COUNT(vm.pData))&31;
|
||||||
|
@ -1916,8 +1902,14 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
insptr++;
|
insptr++;
|
||||||
if (!RR || ((g_spriteExtra[vm.spriteNum] < 1 || g_spriteExtra[vm.spriteNum] == 128) && A_CheckSpriteFlags(vm.spriteNum, SFLAG_KILLCOUNT)))
|
if (RR)
|
||||||
|
{
|
||||||
|
// This check does not exist in Duke Nukem.
|
||||||
|
if ((g_spriteExtra[vm.spriteNum] < 1 || g_spriteExtra[vm.spriteNum] == 128)
|
||||||
|
&& (!RR || A_CheckSpriteFlags(vm.spriteNum, SFLAG_KILLCOUNT)))
|
||||||
P_AddKills(pPlayer, *insptr);
|
P_AddKills(pPlayer, *insptr);
|
||||||
|
}
|
||||||
|
else P_AddKills(pPlayer, *insptr);
|
||||||
insptr++;
|
insptr++;
|
||||||
vm.pActor->actorstayput = -1;
|
vm.pActor->actorstayput = -1;
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -74,7 +74,6 @@ void A_Fall(int spriteNum);
|
||||||
int32_t A_GetFurthestAngle(int spriteNum, int angDiv);
|
int32_t A_GetFurthestAngle(int spriteNum, int angDiv);
|
||||||
void A_GetZLimits(int spriteNum);
|
void A_GetZLimits(int spriteNum);
|
||||||
int32_t __fastcall G_GetAngleDelta(int32_t currAngle, int32_t newAngle);
|
int32_t __fastcall G_GetAngleDelta(int32_t currAngle, int32_t newAngle);
|
||||||
fix16_t __fastcall G_GetQ16AngleDelta(fix16_t oldAngle, fix16_t newAngle);
|
|
||||||
//void G_RestoreMapState();
|
//void G_RestoreMapState();
|
||||||
//void G_SaveMapState();
|
//void G_SaveMapState();
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "menus.h"
|
#include "menus.h"
|
||||||
#include "savegame.h"
|
#include "savegame.h"
|
||||||
#include "namesdyn.h"
|
#include "namesdyn.h"
|
||||||
|
@ -654,18 +654,32 @@ static int32_t G_StaticToDynamicSound(int32_t const sound)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initialize WEAPONx_* gamevars. In C-CON, a new CON variable is defined together with
|
// Initialize WEAPONx_* gamevars. Since for Lunatic, they reside on the C side,
|
||||||
|
// they're set directly. In C-CON, a new CON variable is defined together with
|
||||||
// its initial value.
|
// its initial value.
|
||||||
|
#ifdef LUNATIC
|
||||||
|
# define ADDWEAPONVAR(Weapidx, Membname) do { \
|
||||||
|
int32_t j; \
|
||||||
|
for (j=0; j<MAXPLAYERS; j++) \
|
||||||
|
g_playerWeapon[j][Weapidx].Membname = weapondefaults[Weapidx].Membname; \
|
||||||
|
} while (0)
|
||||||
|
#else
|
||||||
# define ADDWEAPONVAR(Weapidx, Membname) do { \
|
# define ADDWEAPONVAR(Weapidx, Membname) do { \
|
||||||
FStringf aszBuf("WEAPON%d_" #Membname, Weapidx); \
|
FStringf aszBuf("WEAPON%d_" #Membname, Weapidx); \
|
||||||
aszBuf.ToUpper(); \
|
aszBuf.ToUpper(); \
|
||||||
Gv_NewVar(aszBuf, weapondefaults[Weapidx].Membname, GAMEVAR_PERPLAYER | GAMEVAR_SYSTEM); \
|
Gv_NewVar(aszBuf, weapondefaults[Weapidx].Membname, GAMEVAR_PERPLAYER | GAMEVAR_SYSTEM); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
#endif
|
||||||
|
|
||||||
// After CON translation, get not-overridden members from weapondefaults[] back
|
// After CON translation, get not-overridden members from weapondefaults[] back
|
||||||
// into the live arrays!
|
// into the live arrays! (That is, g_playerWeapon[][] for Lunatic, WEAPONx_*
|
||||||
|
// gamevars on the CON side in C-CON.)
|
||||||
|
#ifdef LUNATIC
|
||||||
|
# define POSTADDWEAPONVAR(Weapidx, Membname) ADDWEAPONVAR(Weapidx, Membname)
|
||||||
|
#else
|
||||||
// NYI
|
// NYI
|
||||||
# define POSTADDWEAPONVAR(Weapidx, Membname) do {} while (0)
|
# define POSTADDWEAPONVAR(Weapidx, Membname) do {} while (0)
|
||||||
|
#endif
|
||||||
|
|
||||||
// Finish a default weapon member after CON translation. If it was not
|
// Finish a default weapon member after CON translation. If it was not
|
||||||
// overridden from CON itself (see example at g_weaponOverridden[]), we set
|
// overridden from CON itself (see example at g_weaponOverridden[]), we set
|
||||||
|
@ -700,7 +714,9 @@ void Gv_FinalizeWeaponDefaults(void)
|
||||||
#undef FINISH_WEAPON_DEFAULT_X
|
#undef FINISH_WEAPON_DEFAULT_X
|
||||||
#undef POSTADDWEAPONVAR
|
#undef POSTADDWEAPONVAR
|
||||||
|
|
||||||
|
#if !defined LUNATIC
|
||||||
static int32_t lastvisinc;
|
static int32_t lastvisinc;
|
||||||
|
#endif
|
||||||
|
|
||||||
static void Gv_AddSystemVars(void)
|
static void Gv_AddSystemVars(void)
|
||||||
{
|
{
|
||||||
|
@ -754,15 +770,26 @@ static void Gv_AddSystemVars(void)
|
||||||
|
|
||||||
void Gv_Init(void)
|
void Gv_Init(void)
|
||||||
{
|
{
|
||||||
|
#if !defined LUNATIC
|
||||||
// already initialized
|
// already initialized
|
||||||
if (aGameVars[0].flags)
|
if (aGameVars[0].flags)
|
||||||
return;
|
return;
|
||||||
|
#else
|
||||||
|
static int32_t inited=0;
|
||||||
|
if (inited)
|
||||||
|
return;
|
||||||
|
inited = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
// Set up weapon defaults, g_playerWeapon[][].
|
// Set up weapon defaults, g_playerWeapon[][].
|
||||||
Gv_AddSystemVars();
|
Gv_AddSystemVars();
|
||||||
|
#if !defined LUNATIC
|
||||||
Gv_InitWeaponPointers();
|
Gv_InitWeaponPointers();
|
||||||
|
#endif
|
||||||
|
Gv_ResetSystemDefaults();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if !defined LUNATIC
|
||||||
void Gv_InitWeaponPointers(void)
|
void Gv_InitWeaponPointers(void)
|
||||||
{
|
{
|
||||||
char aszBuf[64];
|
char aszBuf[64];
|
||||||
|
@ -826,5 +853,6 @@ void Gv_RefreshPointers(void)
|
||||||
aGameVars[Gv_GetVarIndex("RESPAWN_MONSTERS")].global = (intptr_t)&ud.respawn_monsters;
|
aGameVars[Gv_GetVarIndex("RESPAWN_MONSTERS")].global = (intptr_t)&ud.respawn_monsters;
|
||||||
aGameVars[Gv_GetVarIndex("VOLUME")].global = (intptr_t)&ud.volume_number;
|
aGameVars[Gv_GetVarIndex("VOLUME")].global = (intptr_t)&ud.volume_number;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
END_DUKE_NS
|
END_DUKE_NS
|
||||||
|
|
|
@ -23,7 +23,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#define global_c_
|
#define global_c_
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
|
|
||||||
BEGIN_DUKE_NS
|
BEGIN_DUKE_NS
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "build.h"
|
#include "build.h"
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "mmulti.h"
|
#include "mmulti.h"
|
||||||
#include "quotes.h"
|
#include "quotes.h"
|
||||||
#include "sector.h"
|
#include "sector.h"
|
||||||
|
@ -46,6 +46,7 @@ BEGIN_DUKE_NS
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define MAXINTERPOLATIONS MAXSPRITES
|
#define MAXINTERPOLATIONS MAXSPRITES
|
||||||
|
// KEEPINSYNC lunatic/con_lang.lua
|
||||||
|
|
||||||
// duke3d global soup :(
|
// duke3d global soup :(
|
||||||
|
|
||||||
|
@ -66,7 +67,6 @@ enum DUKE3D_GLOBALFLAGS {
|
||||||
DUKE3D_NO_PALETTE_CHANGES = 1<<2,
|
DUKE3D_NO_PALETTE_CHANGES = 1<<2,
|
||||||
};
|
};
|
||||||
|
|
||||||
G_EXTERN DukeStatus_t sbar;
|
|
||||||
G_EXTERN actor_t actor[MAXSPRITES];
|
G_EXTERN actor_t actor[MAXSPRITES];
|
||||||
// g_tile: tile-specific data THAT DOES NOT CHANGE during the course of a game
|
// g_tile: tile-specific data THAT DOES NOT CHANGE during the course of a game
|
||||||
G_EXTERN tiledata_t g_tile[MAXTILES];
|
G_EXTERN tiledata_t g_tile[MAXTILES];
|
||||||
|
|
|
@ -25,7 +25,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
#include "enet.h"
|
#include "enet.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "game.h"
|
#include "game.h"
|
||||||
#include "gamedef.h"
|
#include "gamedef.h"
|
||||||
#include "net.h"
|
#include "net.h"
|
||||||
|
|
|
@ -25,7 +25,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
#include "cheats.h"
|
#include "cheats.h"
|
||||||
#include "cmdline.h"
|
#include "cmdline.h"
|
||||||
#include "demo.h" // g_firstDemoFile[]
|
#include "demo.h" // g_firstDemoFile[]
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "menus.h"
|
#include "menus.h"
|
||||||
#include "osdcmds.h"
|
#include "osdcmds.h"
|
||||||
#include "savegame.h"
|
#include "savegame.h"
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -132,6 +132,7 @@ typedef struct {
|
||||||
// * char --> int8_t
|
// * char --> int8_t
|
||||||
// Need to carefully think about implications!
|
// Need to carefully think about implications!
|
||||||
// TODO: rearrange this if the opportunity arises!
|
// TODO: rearrange this if the opportunity arises!
|
||||||
|
// KEEPINSYNC lunatic/_defs_game.lua
|
||||||
typedef struct {
|
typedef struct {
|
||||||
vec3_t pos, opos, vel, npos;
|
vec3_t pos, opos, vel, npos;
|
||||||
vec2_t bobpos, fric;
|
vec2_t bobpos, fric;
|
||||||
|
@ -151,10 +152,9 @@ typedef struct {
|
||||||
|
|
||||||
int16_t loogiex[64], loogiey[64], sbs, sound_pitch;
|
int16_t loogiex[64], loogiey[64], sbs, sound_pitch;
|
||||||
|
|
||||||
int16_t cursectnum, last_extra, subweapon;
|
int16_t cursectnum, look_ang, last_extra, subweapon;
|
||||||
int16_t max_ammo_amount[MAX_WEAPONS], ammo_amount[MAX_WEAPONS], inv_amount[GET_MAX];
|
int16_t max_ammo_amount[MAX_WEAPONS], ammo_amount[MAX_WEAPONS], inv_amount[GET_MAX];
|
||||||
int16_t wackedbyactor, pyoff, opyoff;
|
int16_t wackedbyactor, pyoff, opyoff;
|
||||||
fix16_t q16look_ang;
|
|
||||||
|
|
||||||
int16_t newowner, jumping_counter, airleft;
|
int16_t newowner, jumping_counter, airleft;
|
||||||
int16_t fta, ftq, access_wallnum, access_spritenum;
|
int16_t fta, ftq, access_wallnum, access_spritenum;
|
||||||
|
@ -163,12 +163,10 @@ typedef struct {
|
||||||
int16_t random_club_frame, one_eighty_count;
|
int16_t random_club_frame, one_eighty_count;
|
||||||
int16_t dummyplayersprite, extra_extra8;
|
int16_t dummyplayersprite, extra_extra8;
|
||||||
int16_t actorsqu, timebeforeexit, customexitsound, last_pissed_time;
|
int16_t actorsqu, timebeforeexit, customexitsound, last_pissed_time;
|
||||||
fix16_t one_eighty_target;
|
|
||||||
|
|
||||||
int16_t weaprecs[MAX_WEAPON_RECS], weapon_sway, crack_time, bobcounter;
|
int16_t weaprecs[MAX_WEAPON_RECS], weapon_sway, crack_time, bobcounter;
|
||||||
|
|
||||||
int16_t dead_flag;
|
int16_t orotscrnang, rotscrnang, dead_flag; // JBF 20031220: added orotscrnang
|
||||||
fix16_t oq16rotscrnang, q16rotscrnang; // JBF 20031220: added orotscrnang
|
|
||||||
int16_t holoduke_on, pycount;
|
int16_t holoduke_on, pycount;
|
||||||
int16_t transporter_hold/*, clipdist*/;
|
int16_t transporter_hold/*, clipdist*/;
|
||||||
|
|
||||||
|
@ -212,7 +210,7 @@ typedef struct {
|
||||||
int16_t drink_amt, eat_amt, drink_ang, eat_ang;
|
int16_t drink_amt, eat_amt, drink_ang, eat_ang;
|
||||||
int32_t drink_timer, eat_timer;
|
int32_t drink_timer, eat_timer;
|
||||||
int16_t level_end_timer;
|
int16_t level_end_timer;
|
||||||
int16_t moto_speed, moto_drink;
|
int16_t moto_speed, tilt_status, moto_drink;
|
||||||
uint8_t on_motorcycle, on_boat, moto_underwater, not_on_water, moto_on_ground;
|
uint8_t on_motorcycle, on_boat, moto_underwater, not_on_water, moto_on_ground;
|
||||||
uint8_t moto_do_bump, moto_bump_fast, moto_on_oil, moto_on_mud;
|
uint8_t moto_do_bump, moto_bump_fast, moto_on_oil, moto_on_mud;
|
||||||
int16_t moto_bump, moto_bump_target, moto_turb;
|
int16_t moto_bump, moto_bump_target, moto_turb;
|
||||||
|
@ -222,7 +220,6 @@ typedef struct {
|
||||||
int32_t drug_timer;
|
int32_t drug_timer;
|
||||||
int32_t sea_sick;
|
int32_t sea_sick;
|
||||||
uint8_t hurt_delay2, nocheat;
|
uint8_t hurt_delay2, nocheat;
|
||||||
double tilt_status;
|
|
||||||
|
|
||||||
int32_t dhat60f, dhat613, dhat617, dhat61b, dhat61f;
|
int32_t dhat60f, dhat613, dhat617, dhat61b, dhat61f;
|
||||||
|
|
||||||
|
@ -230,6 +227,7 @@ typedef struct {
|
||||||
int8_t padding_[3];
|
int8_t padding_[3];
|
||||||
} DukePlayer_t;
|
} DukePlayer_t;
|
||||||
|
|
||||||
|
// KEEPINSYNC lunatic/_defs_game.lua
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
DukePlayer_t *ps;
|
DukePlayer_t *ps;
|
||||||
|
@ -237,10 +235,7 @@ typedef struct
|
||||||
|
|
||||||
bool horizRecenter;
|
bool horizRecenter;
|
||||||
float horizAngleAdjust;
|
float horizAngleAdjust;
|
||||||
int8_t horizSkew;
|
fix16_t horizSkew;
|
||||||
bool lookLeft;
|
|
||||||
bool lookRight;
|
|
||||||
double lastInputTicks;
|
|
||||||
|
|
||||||
int32_t movefifoend, syncvalhead, myminlag;
|
int32_t movefifoend, syncvalhead, myminlag;
|
||||||
int32_t pcolor, pteam;
|
int32_t pcolor, pteam;
|
||||||
|
@ -253,6 +248,7 @@ typedef struct
|
||||||
} playerdata_t;
|
} playerdata_t;
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
|
|
||||||
|
// KEEPINSYNC lunatic/con_lang.lua
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
// NOTE: the member names must be identical to aplWeapon* suffixes.
|
// NOTE: the member names must be identical to aplWeapon* suffixes.
|
||||||
|
@ -274,6 +270,10 @@ typedef struct
|
||||||
int32_t FlashColor; // Muzzle flash color
|
int32_t FlashColor; // Muzzle flash color
|
||||||
} weapondata_t;
|
} weapondata_t;
|
||||||
|
|
||||||
|
#ifdef LUNATIC
|
||||||
|
# define PWEAPON(Player, Weapon, Wmember) (g_playerWeapon[Player][Weapon].Wmember)
|
||||||
|
extern weapondata_t g_playerWeapon[MAXPLAYERS][MAX_WEAPONS];
|
||||||
|
#else
|
||||||
# define PWEAPON(Player, Weapon, Wmember) (aplWeapon ## Wmember [Weapon][Player])
|
# define PWEAPON(Player, Weapon, Wmember) (aplWeapon ## Wmember [Weapon][Player])
|
||||||
extern intptr_t *aplWeaponClip[MAX_WEAPONS]; // number of items in clip
|
extern intptr_t *aplWeaponClip[MAX_WEAPONS]; // number of items in clip
|
||||||
extern intptr_t *aplWeaponReload[MAX_WEAPONS]; // delay to reload (include fire)
|
extern intptr_t *aplWeaponReload[MAX_WEAPONS]; // delay to reload (include fire)
|
||||||
|
@ -291,7 +291,9 @@ extern intptr_t *aplWeaponFireSound[MAX_WEAPONS]; // Sound made wh
|
||||||
extern intptr_t *aplWeaponSound2Time[MAX_WEAPONS]; // Alternate sound time
|
extern intptr_t *aplWeaponSound2Time[MAX_WEAPONS]; // Alternate sound time
|
||||||
extern intptr_t *aplWeaponSound2Sound[MAX_WEAPONS]; // Alternate sound sound ID
|
extern intptr_t *aplWeaponSound2Sound[MAX_WEAPONS]; // Alternate sound sound ID
|
||||||
extern intptr_t *aplWeaponFlashColor[MAX_WEAPONS]; // Color for polymer muzzle flash
|
extern intptr_t *aplWeaponFlashColor[MAX_WEAPONS]; // Color for polymer muzzle flash
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// KEEPINSYNC lunatic/_defs_game.lua
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int32_t cur, count; // "cur" is the only member that is *used*
|
int32_t cur, count; // "cur" is the only member that is *used*
|
||||||
int32_t gunposx, lookhalfang; // weapon_xoffset, ps->look_ang>>1
|
int32_t gunposx, lookhalfang; // weapon_xoffset, ps->look_ang>>1
|
||||||
|
|
|
@ -21,7 +21,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "anim.h"
|
#include "anim.h"
|
||||||
#include "menus.h"
|
#include "menus.h"
|
||||||
#include "demo.h"
|
#include "demo.h"
|
||||||
|
@ -812,7 +812,7 @@ void P_ResetPlayer(int playerNum)
|
||||||
pPlayer->fta = 0;
|
pPlayer->fta = 0;
|
||||||
pPlayer->ftq = 0;
|
pPlayer->ftq = 0;
|
||||||
pPlayer->vel.x = pPlayer->vel.y = 0;
|
pPlayer->vel.x = pPlayer->vel.y = 0;
|
||||||
if (!RR) pPlayer->q16rotscrnang = 0;
|
if (!RR) pPlayer->rotscrnang = 0;
|
||||||
pPlayer->runspeed = g_playerFriction;
|
pPlayer->runspeed = g_playerFriction;
|
||||||
pPlayer->falling_counter = 0;
|
pPlayer->falling_counter = 0;
|
||||||
|
|
||||||
|
@ -904,9 +904,9 @@ void P_ResetStatus(int playerNum)
|
||||||
pPlayer->heat_on = 0;
|
pPlayer->heat_on = 0;
|
||||||
pPlayer->jetpack_on = 0;
|
pPlayer->jetpack_on = 0;
|
||||||
pPlayer->holoduke_on = -1;
|
pPlayer->holoduke_on = -1;
|
||||||
pPlayer->q16look_ang = fix16_from_int(512 - ((ud.level_number & 1) << 10));
|
pPlayer->look_ang = 512 - ((ud.level_number & 1) << 10);
|
||||||
pPlayer->q16rotscrnang = 0;
|
pPlayer->rotscrnang = 0;
|
||||||
pPlayer->oq16rotscrnang = fix16_one; // JBF 20031220
|
pPlayer->orotscrnang = 1; // JBF 20031220
|
||||||
pPlayer->newowner = -1;
|
pPlayer->newowner = -1;
|
||||||
pPlayer->jumping_counter = 0;
|
pPlayer->jumping_counter = 0;
|
||||||
pPlayer->hard_landing = 0;
|
pPlayer->hard_landing = 0;
|
||||||
|
@ -932,10 +932,6 @@ void P_ResetStatus(int playerNum)
|
||||||
pPlayer->movement_lock = 0;
|
pPlayer->movement_lock = 0;
|
||||||
pPlayer->frag_ps = playerNum;
|
pPlayer->frag_ps = playerNum;
|
||||||
|
|
||||||
g_player[playerNum].horizRecenter = 0;
|
|
||||||
g_player[playerNum].horizSkew = 0;
|
|
||||||
g_player[playerNum].horizAngleAdjust = 0;
|
|
||||||
|
|
||||||
P_UpdateScreenPal(pPlayer);
|
P_UpdateScreenPal(pPlayer);
|
||||||
|
|
||||||
if (RR)
|
if (RR)
|
||||||
|
@ -1150,7 +1146,7 @@ static void resetprestat(int playerNum, int gameMode)
|
||||||
g_animateCnt = 0;
|
g_animateCnt = 0;
|
||||||
parallaxtype = 0;
|
parallaxtype = 0;
|
||||||
randomseed = 17;
|
randomseed = 17;
|
||||||
paused = 0;
|
ud.pause_on = 0;
|
||||||
ud.camerasprite = -1;
|
ud.camerasprite = -1;
|
||||||
ud.eog = 0;
|
ud.eog = 0;
|
||||||
tempwallptr = 0;
|
tempwallptr = 0;
|
||||||
|
@ -2289,7 +2285,7 @@ int G_EnterLevel(int gameMode)
|
||||||
|
|
||||||
//if (g_networkMode != NET_DEDICATED_SERVER)
|
//if (g_networkMode != NET_DEDICATED_SERVER)
|
||||||
{
|
{
|
||||||
S_ResumeSound(false);
|
S_PauseSounds(false);
|
||||||
FX_StopAllSounds();
|
FX_StopAllSounds();
|
||||||
S_ClearSoundLocks();
|
S_ClearSoundLocks();
|
||||||
FX_SetReverb(0);
|
FX_SetReverb(0);
|
||||||
|
@ -2464,9 +2460,6 @@ int G_EnterLevel(int gameMode)
|
||||||
P_UpdateScreenPal(g_player[myconnectindex].ps);
|
P_UpdateScreenPal(g_player[myconnectindex].ps);
|
||||||
renderFlushPerms();
|
renderFlushPerms();
|
||||||
|
|
||||||
// reset lastInputTicks.
|
|
||||||
g_player[myconnectindex].lastInputTicks = 0;
|
|
||||||
|
|
||||||
everyothertime = 0;
|
everyothertime = 0;
|
||||||
g_globalRandom = 0;
|
g_globalRandom = 0;
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "baselayer.h"
|
#include "baselayer.h"
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "sounds.h"
|
#include "sounds.h"
|
||||||
#include "i_time.h"
|
#include "i_time.h"
|
||||||
#include "files.h"
|
#include "files.h"
|
||||||
|
|
|
@ -21,7 +21,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "premap.h"
|
#include "premap.h"
|
||||||
#include "prlights.h"
|
#include "prlights.h"
|
||||||
#include "savegame.h"
|
#include "savegame.h"
|
||||||
|
@ -183,7 +183,7 @@ int32_t G_LoadPlayer(const char *path)
|
||||||
|
|
||||||
// some setup first
|
// some setup first
|
||||||
ud.multimode = h.numplayers;
|
ud.multimode = h.numplayers;
|
||||||
S_PauseSound(true, false);
|
S_PauseSounds(true);
|
||||||
|
|
||||||
if (numplayers > 1)
|
if (numplayers > 1)
|
||||||
{
|
{
|
||||||
|
@ -834,7 +834,7 @@ static const dataspec_t svgm_udnetw[] =
|
||||||
{ DS_NOCHK, &ud.ffire, sizeof(ud.ffire), 1 },
|
{ DS_NOCHK, &ud.ffire, sizeof(ud.ffire), 1 },
|
||||||
{ DS_NOCHK, &ud.noexits, sizeof(ud.noexits), 1 },
|
{ DS_NOCHK, &ud.noexits, sizeof(ud.noexits), 1 },
|
||||||
{ DS_NOCHK, &ud.playerai, sizeof(ud.playerai), 1 },
|
{ DS_NOCHK, &ud.playerai, sizeof(ud.playerai), 1 },
|
||||||
{ 0, &paused, sizeof(paused), 1 },
|
{ 0, &ud.pause_on, sizeof(ud.pause_on), 1 },
|
||||||
{ 0, connectpoint2, sizeof(connectpoint2), 1 },
|
{ 0, connectpoint2, sizeof(connectpoint2), 1 },
|
||||||
{ 0, &randomseed, sizeof(randomseed), 1 },
|
{ 0, &randomseed, sizeof(randomseed), 1 },
|
||||||
{ 0, &g_globalRandom, sizeof(g_globalRandom), 1 },
|
{ 0, &g_globalRandom, sizeof(g_globalRandom), 1 },
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -30,9 +30,6 @@ static FORCE_INLINE int32_t sbarsc(int32_t sc)
|
||||||
return scale(sc, ud.statusbarscale, 100);
|
return scale(sc, ud.statusbarscale, 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t sbarx16(int32_t x);
|
|
||||||
int32_t sbarxr16(int32_t x);
|
|
||||||
int32_t sbary16(int32_t y);
|
|
||||||
void G_DrawInventory(const DukePlayer_t *p);
|
void G_DrawInventory(const DukePlayer_t *p);
|
||||||
void G_DrawStatusBar(int32_t snum);
|
void G_DrawStatusBar(int32_t snum);
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "screens.h"
|
#include "screens.h"
|
||||||
|
|
||||||
|
@ -765,7 +765,7 @@ void G_DisplayRest(int32_t smoothratio)
|
||||||
|
|
||||||
if (ud.scrollmode == 0)
|
if (ud.scrollmode == 0)
|
||||||
{
|
{
|
||||||
if (pp->newowner == -1 && !paused)
|
if (pp->newowner == -1 && !ud.pause_on)
|
||||||
{
|
{
|
||||||
if (screenpeek == myconnectindex && numplayers > 1)
|
if (screenpeek == myconnectindex && numplayers > 1)
|
||||||
{
|
{
|
||||||
|
@ -789,7 +789,7 @@ void G_DisplayRest(int32_t smoothratio)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (!paused)
|
if (!ud.pause_on)
|
||||||
{
|
{
|
||||||
ud.fola += ud.folavel>>3;
|
ud.fola += ud.folavel>>3;
|
||||||
ud.folx += (ud.folfvel*sintable[(512+2048-ud.fola)&2047])>>14;
|
ud.folx += (ud.folfvel*sintable[(512+2048-ud.fola)&2047])>>14;
|
||||||
|
@ -822,7 +822,6 @@ void G_DisplayRest(int32_t smoothratio)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pp->invdisptime > 0) G_DrawInventory(pp);
|
|
||||||
|
|
||||||
//if (VM_OnEvent(EVENT_DISPLAYSBAR, g_player[screenpeek].ps->i, screenpeek) == 0)
|
//if (VM_OnEvent(EVENT_DISPLAYSBAR, g_player[screenpeek].ps->i, screenpeek) == 0)
|
||||||
G_DrawStatusBar(screenpeek);
|
G_DrawStatusBar(screenpeek);
|
||||||
|
@ -844,12 +843,12 @@ void G_DisplayRest(int32_t smoothratio)
|
||||||
if (!DEER && g_player[myconnectindex].ps->newowner == -1 && ud.overhead_on == 0 && cl_crosshair && ud.camerasprite == -1)
|
if (!DEER && g_player[myconnectindex].ps->newowner == -1 && ud.overhead_on == 0 && cl_crosshair && ud.camerasprite == -1)
|
||||||
{
|
{
|
||||||
int32_t a = CROSSHAIR;
|
int32_t a = CROSSHAIR;
|
||||||
//ud.returnvar[0] = (160<<16) - (fix16_to_int(g_player[myconnectindex].ps->q16look_ang)<<15);
|
//ud.returnvar[0] = (160<<16) - (g_player[myconnectindex].ps->look_ang<<15);
|
||||||
//ud.returnvar[1] = 100<<16;
|
//ud.returnvar[1] = 100<<16;
|
||||||
//int32_t a = VM_OnEventWithReturn(EVENT_DISPLAYCROSSHAIR, g_player[screenpeek].ps->i, screenpeek, CROSSHAIR);
|
//int32_t a = VM_OnEventWithReturn(EVENT_DISPLAYCROSSHAIR, g_player[screenpeek].ps->i, screenpeek, CROSSHAIR);
|
||||||
if ((unsigned) a < MAXTILES)
|
if ((unsigned) a < MAXTILES)
|
||||||
{
|
{
|
||||||
vec2_t crosshairpos = { (160<<16) - (fix16_to_int(g_player[myconnectindex].ps->q16look_ang)<<15), 100<<16 };
|
vec2_t crosshairpos = { (160<<16) - (g_player[myconnectindex].ps->look_ang<<15), 100<<16 };
|
||||||
//vec2_t crosshairpos = { ud.returnvar[0], ud.returnvar[1] };
|
//vec2_t crosshairpos = { ud.returnvar[0], ud.returnvar[1] };
|
||||||
uint32_t crosshair_o = 1|2;
|
uint32_t crosshair_o = 1|2;
|
||||||
uint32_t crosshair_scale = divscale16(cl_crosshairscale, 100);
|
uint32_t crosshair_scale = divscale16(cl_crosshairscale, 100);
|
||||||
|
@ -869,10 +868,10 @@ void G_DisplayRest(int32_t smoothratio)
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (paused==1 && (g_player[myconnectindex].ps->gm&MODE_MENU) == 0)
|
if (ud.pause_on==1 && (g_player[myconnectindex].ps->gm&MODE_MENU) == 0)
|
||||||
menutext_center(100, GStrings("Game Paused"));
|
menutext_center(100, GStrings("Game Paused"));
|
||||||
|
|
||||||
mdpause = (paused || (ud.recstat==2 && (g_demo_paused && g_demo_goalCnt==0)) || (g_player[myconnectindex].ps->gm&MODE_MENU && numplayers < 2));
|
mdpause = (ud.pause_on || (ud.recstat==2 && (g_demo_paused && g_demo_goalCnt==0)) || (g_player[myconnectindex].ps->gm&MODE_MENU && numplayers < 2));
|
||||||
|
|
||||||
// JBF 20040124: display level stats in screen corner
|
// JBF 20040124: display level stats in screen corner
|
||||||
if (ud.overhead_on != 2 && hud_stats) // && VM_OnEvent(EVENT_DISPLAYLEVELSTATS, g_player[screenpeek].ps->i, screenpeek) == 0)
|
if (ud.overhead_on != 2 && hud_stats) // && VM_OnEvent(EVENT_DISPLAYLEVELSTATS, g_player[screenpeek].ps->i, screenpeek) == 0)
|
||||||
|
|
|
@ -23,7 +23,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#define sector_c_
|
#define sector_c_
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
|
|
||||||
#include "secrets.h"
|
#include "secrets.h"
|
||||||
#include "v_video.h"
|
#include "v_video.h"
|
||||||
|
@ -506,8 +506,11 @@ static void G_SetupCamTile(int spriteNum, int tileNum, int smoothRatio)
|
||||||
vec3_t const camera = G_GetCameraPosition(spriteNum, smoothRatio);
|
vec3_t const camera = G_GetCameraPosition(spriteNum, smoothRatio);
|
||||||
int const saveMirror = display_mirror;
|
int const saveMirror = display_mirror;
|
||||||
|
|
||||||
renderSetTarget(tileNum, tilesiz[tileNum].y, tilesiz[tileNum].x);
|
auto canvas = renderSetTarget(tileNum);
|
||||||
|
if (!canvas) return;
|
||||||
|
|
||||||
|
screen->RenderTextureView(canvas, [=](IntRect& rect)
|
||||||
|
{
|
||||||
yax_preparedrawrooms();
|
yax_preparedrawrooms();
|
||||||
drawrooms(camera.x, camera.y, camera.z, SA(spriteNum), 100 + sprite[spriteNum].shade, SECT(spriteNum));
|
drawrooms(camera.x, camera.y, camera.z, SA(spriteNum), 100 + sprite[spriteNum].shade, SECT(spriteNum));
|
||||||
yax_drawrooms(G_DoSpriteAnimations, SECT(spriteNum), 0, smoothRatio);
|
yax_drawrooms(G_DoSpriteAnimations, SECT(spriteNum), 0, smoothRatio);
|
||||||
|
@ -517,7 +520,9 @@ static void G_SetupCamTile(int spriteNum, int tileNum, int smoothRatio)
|
||||||
display_mirror = saveMirror;
|
display_mirror = saveMirror;
|
||||||
renderDrawMasks();
|
renderDrawMasks();
|
||||||
|
|
||||||
|
});
|
||||||
renderRestoreTarget();
|
renderRestoreTarget();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void G_AnimateCamSprite(int smoothRatio)
|
void G_AnimateCamSprite(int smoothRatio)
|
||||||
|
@ -3647,7 +3652,29 @@ void P_HandleSharedKeys(int playerNum)
|
||||||
{
|
{
|
||||||
pPlayer->interface_toggle_flag = 1;
|
pPlayer->interface_toggle_flag = 1;
|
||||||
|
|
||||||
if (paused) return;
|
if (TEST_SYNC_KEY(playerBits, SK_PAUSE))
|
||||||
|
{
|
||||||
|
inputState.ClearKeyStatus(sc_Pause);
|
||||||
|
if (ud.pause_on)
|
||||||
|
ud.pause_on = 0;
|
||||||
|
else ud.pause_on = 1+SHIFTS_IS_PRESSED;
|
||||||
|
if (ud.pause_on)
|
||||||
|
{
|
||||||
|
Mus_SetPaused(true);
|
||||||
|
S_PauseSounds(true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Mus_SetPaused(false);
|
||||||
|
|
||||||
|
S_PauseSounds(false);
|
||||||
|
|
||||||
|
pub = NUMPAGES;
|
||||||
|
pus = NUMPAGES;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ud.pause_on) return;
|
||||||
|
|
||||||
if (sprite[pPlayer->i].extra <= 0) return; // if dead...
|
if (sprite[pPlayer->i].extra <= 0) return; // if dead...
|
||||||
|
|
||||||
|
@ -4225,10 +4252,7 @@ rrtripbomb_case:
|
||||||
|
|
||||||
if (TEST_SYNC_KEY(playerBits, SK_TURNAROUND) && pPlayer->one_eighty_count == 0)
|
if (TEST_SYNC_KEY(playerBits, SK_TURNAROUND) && pPlayer->one_eighty_count == 0)
|
||||||
if (VM_OnEvent(EVENT_TURNAROUND,pPlayer->i,playerNum) == 0)
|
if (VM_OnEvent(EVENT_TURNAROUND,pPlayer->i,playerNum) == 0)
|
||||||
{
|
|
||||||
pPlayer->one_eighty_count = -1024;
|
pPlayer->one_eighty_count = -1024;
|
||||||
pPlayer->one_eighty_target = fix16_sadd(pPlayer->q16ang, -fix16_from_int(pPlayer->one_eighty_count)) & 0x7FFFFFF;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "raze_music.h"
|
#include "raze_music.h"
|
||||||
#include "mapinfo.h"
|
#include "mapinfo.h"
|
||||||
#include "raze_sound.h"
|
#include "raze_sound.h"
|
||||||
|
@ -79,6 +79,17 @@ TArray<uint8_t> DukeSoundEngine::ReadSound(int lumpnum)
|
||||||
//
|
//
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
|
|
||||||
|
void S_PauseSounds(bool paused)
|
||||||
|
{
|
||||||
|
soundEngine->SetPaused(paused);
|
||||||
|
}
|
||||||
|
|
||||||
|
//==========================================================================
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//==========================================================================
|
||||||
|
|
||||||
void cacheAllSounds(void)
|
void cacheAllSounds(void)
|
||||||
{
|
{
|
||||||
auto& sfx = soundEngine->GetSounds();
|
auto& sfx = soundEngine->GetSounds();
|
||||||
|
@ -86,6 +97,8 @@ void cacheAllSounds(void)
|
||||||
for(auto &snd : sfx)
|
for(auto &snd : sfx)
|
||||||
{
|
{
|
||||||
soundEngine->CacheSound(&snd);
|
soundEngine->CacheSound(&snd);
|
||||||
|
if (((++i)&31) == 0)
|
||||||
|
G_HandleAsync();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,6 +35,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
BEGIN_DUKE_NS
|
BEGIN_DUKE_NS
|
||||||
|
|
||||||
|
// KEEPINSYNC lunatic/con_lang.lua
|
||||||
#define MAXSOUNDS 4096
|
#define MAXSOUNDS 4096
|
||||||
#define LOUDESTVOLUME 111
|
#define LOUDESTVOLUME 111
|
||||||
|
|
||||||
|
@ -56,6 +57,8 @@ inline int S_CheckSoundPlaying(int sprnum, int soundNum) { return S_CheckSoundPl
|
||||||
inline void S_ClearSoundLocks(void) {}
|
inline void S_ClearSoundLocks(void) {}
|
||||||
void cacheAllSounds(void);
|
void cacheAllSounds(void);
|
||||||
void S_MenuSound(void);
|
void S_MenuSound(void);
|
||||||
|
void S_PauseMusic(bool paused);
|
||||||
|
void S_PauseSounds(bool paused);
|
||||||
void S_PlayLevelMusicOrNothing(unsigned int);
|
void S_PlayLevelMusicOrNothing(unsigned int);
|
||||||
int S_TryPlaySpecialMusic(unsigned int);
|
int S_TryPlaySpecialMusic(unsigned int);
|
||||||
void S_PlaySpecialMusicOrNothing(unsigned int);
|
void S_PlaySpecialMusicOrNothing(unsigned int);
|
||||||
|
|
|
@ -21,7 +21,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
#include "ns.h" // Must come before everything else!
|
#include "ns.h" // Must come before everything else!
|
||||||
|
|
||||||
#include "duke3d_ed.h"
|
#include "duke3d.h"
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "sbar.h"
|
#include "sbar.h"
|
||||||
#include "menus.h"
|
#include "menus.h"
|
||||||
|
@ -112,6 +112,23 @@ vec2_t mpgametextsize(const char *t, int32_t f)
|
||||||
return G_ScreenTextSize(MF_Bluefont.tilenum, 0, 0, textsc(MF_Bluefont.zoom), 0, t, 2|8|16|ROTATESPRITE_FULL16, MF_Bluefont.emptychar.x, MF_Bluefont.emptychar.y, MF_Bluefont.between.x, MF_Bluefont.between.y, MF_Bluefont.textflags|f, 0, 0, xdim-1, ydim-1);
|
return G_ScreenTextSize(MF_Bluefont.tilenum, 0, 0, textsc(MF_Bluefont.zoom), 0, t, 2|8|16|ROTATESPRITE_FULL16, MF_Bluefont.emptychar.x, MF_Bluefont.emptychar.y, MF_Bluefont.between.x, MF_Bluefont.between.y, MF_Bluefont.textflags|f, 0, 0, xdim-1, ydim-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int32_t sbarx16(int32_t x)
|
||||||
|
{
|
||||||
|
if (ud.screen_size == 4) return sbarsc(x);
|
||||||
|
return (((320 << 16) - sbarsc(320 << 16)) >> 1) + sbarsc(x);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t sbarxr16(int32_t x)
|
||||||
|
{
|
||||||
|
if (ud.screen_size == 4) return (320 << 16) - sbarsc(x);
|
||||||
|
return (((320 << 16) - sbarsc(320 << 16)) >> 1) + sbarsc(x);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t sbary16(int32_t y)
|
||||||
|
{
|
||||||
|
return (100 << 16) - sbarsc(200 << 16) + sbarsc(y);
|
||||||
|
}
|
||||||
|
|
||||||
// minitext_yofs: in hud_scale-independent, (<<16)-scaled, 0-200-normalized y coords,
|
// minitext_yofs: in hud_scale-independent, (<<16)-scaled, 0-200-normalized y coords,
|
||||||
// (sb&ROTATESPRITE_MAX) only.
|
// (sb&ROTATESPRITE_MAX) only.
|
||||||
int32_t minitext_yofs = 0;
|
int32_t minitext_yofs = 0;
|
||||||
|
|
BIN
wadsrc/static/graphics/tinyblak.png
Normal file
BIN
wadsrc/static/graphics/tinyblak.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 120 B |
Loading…
Reference in a new issue