From 4be53d8527eee1d3b56e7f505faba7cefbcb5dac Mon Sep 17 00:00:00 2001 From: Logan Date: Sat, 10 Oct 2020 13:06:04 -0400 Subject: [PATCH] server: fix monster yaw speed (#137) This makes the yaw speed for all monsters (scientists, headcrabs, etc.) framerate independent. Fix by Solokiller with mikela-valve's adjustments: https://github.com/ValveSoftware/halflife/issues/2458 --- dlls/basemonster.h | 4 ++++ dlls/monsters.cpp | 16 ++++++++++++++++ wscript | 1 + 3 files changed, 21 insertions(+) diff --git a/dlls/basemonster.h b/dlls/basemonster.h index 2234aaf9..48ac9fc9 100644 --- a/dlls/basemonster.h +++ b/dlls/basemonster.h @@ -328,5 +328,9 @@ public: BOOL CineCleanup(); CBaseEntity* DropItem( const char *pszItemName, const Vector &vecPos, const Vector &vecAng );// drop an item. + +#ifdef MONSTER_YAWSPEED_FIX + float m_flLastYawTime; +#endif }; #endif // BASEMONSTER_H diff --git a/dlls/monsters.cpp b/dlls/monsters.cpp index 57de767d..1192b8ca 100644 --- a/dlls/monsters.cpp +++ b/dlls/monsters.cpp @@ -2022,6 +2022,10 @@ void CBaseMonster::MonsterInit( void ) SetThink( &CBaseMonster::MonsterInitThink ); pev->nextthink = gpGlobals->time + 0.1f; SetUse( &CBaseMonster::MonsterUse ); + +#ifdef MONSTER_YAWSPEED_FIX + m_flLastYawTime = gpGlobals->time; +#endif } //========================================================= @@ -2504,7 +2508,15 @@ float CBaseMonster::ChangeYaw( int yawSpeed ) ideal = pev->ideal_yaw; if( current != ideal ) { +#ifdef MONSTER_YAWSPEED_FIX + float delta = gpGlobals->time - m_flLastYawTime; + if( delta > 0.25 ) + delta = 0.25; + + speed = (float)yawSpeed * delta * 2; +#else speed = (float)yawSpeed * gpGlobals->frametime * 10; +#endif move = ideal - current; if( ideal > current ) @@ -2548,6 +2560,10 @@ float CBaseMonster::ChangeYaw( int yawSpeed ) else move = 0; +#ifdef MONSTER_YAWSPEED_FIX + m_flLastYawTime = gpGlobals->time; +#endif + return move; } diff --git a/wscript b/wscript index b08bd906..9c0aba5f 100644 --- a/wscript +++ b/wscript @@ -275,6 +275,7 @@ def configure(conf): conf.define('CROWBAR_DELAY_FIX', False) conf.define('CROWBAR_FIX_RAPID_CROWBAR', False) conf.define('GAUSS_OVERCHARGE_FIX', False) + conf.define('MONSTER_YAWSPEED_FIX', False) if conf.env.DEST_OS == 'android' or conf.options.ENABLE_MOD_HACKS: conf.define('MOBILE_HACKS', '1')