mirror of
https://github.com/s1lentq/ReGameDLL_CS.git
synced 2025-01-14 15:48:01 +03:00
Closes #333
This commit is contained in:
parent
1745de6aca
commit
2903630e38
@ -142,7 +142,11 @@ void CC4::PrimaryAttack()
|
|||||||
SendWeaponAnim(C4_ARM, UseDecrement() != FALSE);
|
SendWeaponAnim(C4_ARM, UseDecrement() != FALSE);
|
||||||
|
|
||||||
// freeze the player in place while planting
|
// freeze the player in place while planting
|
||||||
|
#ifdef REGAMEDLL_FIXES
|
||||||
|
m_pPlayer->ResetMaxSpeed();
|
||||||
|
#else
|
||||||
SET_CLIENT_MAXSPEED(m_pPlayer->edict(), 1.0);
|
SET_CLIENT_MAXSPEED(m_pPlayer->edict(), 1.0);
|
||||||
|
#endif
|
||||||
|
|
||||||
m_pPlayer->SetAnimation(PLAYER_ATTACK1);
|
m_pPlayer->SetAnimation(PLAYER_ATTACK1);
|
||||||
m_pPlayer->SetProgressBarTime(C4_ARMING_ON_TIME);
|
m_pPlayer->SetProgressBarTime(C4_ARMING_ON_TIME);
|
||||||
@ -156,76 +160,73 @@ void CC4::PrimaryAttack()
|
|||||||
|
|
||||||
if (m_fArmedTime <= gpGlobals->time)
|
if (m_fArmedTime <= gpGlobals->time)
|
||||||
{
|
{
|
||||||
if (m_bStartedArming)
|
m_bStartedArming = false;
|
||||||
|
m_fArmedTime = 0;
|
||||||
|
|
||||||
|
Broadcast("BOMBPL");
|
||||||
|
m_pPlayer->m_bHasC4 = false;
|
||||||
|
|
||||||
|
if (pev->speed != 0 && CSGameRules())
|
||||||
{
|
{
|
||||||
m_bStartedArming = false;
|
CSGameRules()->m_iC4Timer = int(pev->speed);
|
||||||
m_fArmedTime = 0;
|
}
|
||||||
|
|
||||||
Broadcast("BOMBPL");
|
|
||||||
m_pPlayer->m_bHasC4 = false;
|
|
||||||
|
|
||||||
if (pev->speed != 0 && CSGameRules())
|
|
||||||
{
|
|
||||||
CSGameRules()->m_iC4Timer = int(pev->speed);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef REGAMEDLL_FIXES
|
#ifdef REGAMEDLL_FIXES
|
||||||
Vector vBombAngles = Vector(0, m_pPlayer->pev->angles[1] - 90.0, 0);
|
Vector vBombAngles = Vector(0, m_pPlayer->pev->angles[1] - 90.0, 0);
|
||||||
#else
|
#else
|
||||||
Vector vBombAngles = Vector(0, 0, 0);
|
Vector vBombAngles = Vector(0, 0, 0);
|
||||||
#endif
|
#endif
|
||||||
CGrenade *pBomb = CGrenade::ShootSatchelCharge(m_pPlayer->pev, m_pPlayer->pev->origin, vBombAngles);
|
CGrenade *pBomb = CGrenade::ShootSatchelCharge(m_pPlayer->pev, m_pPlayer->pev->origin, vBombAngles);
|
||||||
|
|
||||||
MESSAGE_BEGIN(MSG_SPEC, SVC_DIRECTOR);
|
MESSAGE_BEGIN(MSG_SPEC, SVC_DIRECTOR);
|
||||||
WRITE_BYTE(9);
|
WRITE_BYTE(9);
|
||||||
WRITE_BYTE(DRC_CMD_EVENT);
|
WRITE_BYTE(DRC_CMD_EVENT);
|
||||||
WRITE_SHORT(m_pPlayer->entindex());
|
WRITE_SHORT(m_pPlayer->entindex());
|
||||||
WRITE_SHORT(0);
|
WRITE_SHORT(0);
|
||||||
WRITE_LONG(DRC_FLAG_FACEPLAYER | 11);
|
WRITE_LONG(DRC_FLAG_FACEPLAYER | 11);
|
||||||
MESSAGE_END();
|
MESSAGE_END();
|
||||||
|
|
||||||
MESSAGE_BEGIN(MSG_ALL, gmsgBombDrop);
|
MESSAGE_BEGIN(MSG_ALL, gmsgBombDrop);
|
||||||
WRITE_COORD(pBomb->pev->origin.x);
|
WRITE_COORD(pBomb->pev->origin.x);
|
||||||
WRITE_COORD(pBomb->pev->origin.y);
|
WRITE_COORD(pBomb->pev->origin.y);
|
||||||
WRITE_COORD(pBomb->pev->origin.z);
|
WRITE_COORD(pBomb->pev->origin.z);
|
||||||
WRITE_BYTE(BOMB_FLAG_PLANTED);
|
WRITE_BYTE(BOMB_FLAG_PLANTED);
|
||||||
MESSAGE_END();
|
MESSAGE_END();
|
||||||
|
|
||||||
UTIL_ClientPrintAll(HUD_PRINTCENTER, "#Bomb_Planted");
|
UTIL_ClientPrintAll(HUD_PRINTCENTER, "#Bomb_Planted");
|
||||||
if (TheBots)
|
if (TheBots)
|
||||||
{
|
{
|
||||||
TheBots->OnEvent(EVENT_BOMB_PLANTED, m_pPlayer, pBomb);
|
TheBots->OnEvent(EVENT_BOMB_PLANTED, m_pPlayer, pBomb);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (TheCareerTasks && CSGameRules()->IsCareer() && !m_pPlayer->IsBot())
|
if (TheCareerTasks && CSGameRules()->IsCareer() && !m_pPlayer->IsBot())
|
||||||
{
|
{
|
||||||
TheCareerTasks->HandleEvent(EVENT_BOMB_PLANTED, m_pPlayer);
|
TheCareerTasks->HandleEvent(EVENT_BOMB_PLANTED, m_pPlayer);
|
||||||
}
|
}
|
||||||
|
|
||||||
UTIL_LogPrintf("\"%s<%i><%s><TERRORIST>\" triggered \"Planted_The_Bomb\"\n",
|
UTIL_LogPrintf("\"%s<%i><%s><TERRORIST>\" triggered \"Planted_The_Bomb\"\n",
|
||||||
STRING(m_pPlayer->pev->netname),
|
STRING(m_pPlayer->pev->netname),
|
||||||
GETPLAYERUSERID(m_pPlayer->edict()),
|
GETPLAYERUSERID(m_pPlayer->edict()),
|
||||||
GETPLAYERAUTHID(m_pPlayer->edict()));
|
GETPLAYERAUTHID(m_pPlayer->edict()));
|
||||||
|
|
||||||
g_pGameRules->m_bBombDropped = FALSE;
|
g_pGameRules->m_bBombDropped = FALSE;
|
||||||
|
|
||||||
// Play the plant sound.
|
// Play the plant sound.
|
||||||
EMIT_SOUND(edict(), CHAN_WEAPON, "weapons/c4_plant.wav", VOL_NORM, ATTN_NORM);
|
EMIT_SOUND(edict(), CHAN_WEAPON, "weapons/c4_plant.wav", VOL_NORM, ATTN_NORM);
|
||||||
|
|
||||||
// hide the backpack in Terrorist's models.
|
// hide the backpack in Terrorist's models.
|
||||||
m_pPlayer->pev->body = 0;
|
m_pPlayer->pev->body = 0;
|
||||||
|
|
||||||
// release the player from being frozen
|
// release the player from being frozen
|
||||||
m_pPlayer->ResetMaxSpeed();
|
m_pPlayer->ResetMaxSpeed();
|
||||||
|
|
||||||
// No more c4!
|
// No more c4!
|
||||||
m_pPlayer->SetBombIcon(FALSE);
|
m_pPlayer->SetBombIcon(FALSE);
|
||||||
|
|
||||||
if (--m_pPlayer->m_rgAmmo[m_iPrimaryAmmoType] <= 0)
|
if (--m_pPlayer->m_rgAmmo[m_iPrimaryAmmoType] <= 0)
|
||||||
{
|
{
|
||||||
RetireWeapon();
|
RetireWeapon();
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -366,5 +367,10 @@ void CC4::Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, f
|
|||||||
|
|
||||||
float CC4::GetMaxSpeed()
|
float CC4::GetMaxSpeed()
|
||||||
{
|
{
|
||||||
|
#ifdef REGAMEDLL_FIXES
|
||||||
|
if (m_bStartedArming)
|
||||||
|
return 1.0f;
|
||||||
|
#endif
|
||||||
|
|
||||||
return C4_MAX_SPEED;
|
return C4_MAX_SPEED;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user