Slight Grow improvements for public

- Using Grow while Shrunk will make you normal-size, instead of giant.
- Baked in a Shrink/Grow noise into K_RemoveGrowShrink, whenever you have either
This commit is contained in:
TehRealSalt 2019-05-01 23:50:18 -04:00
parent db2935d45a
commit 54af8f5fc0

View file

@ -2124,11 +2124,13 @@ void K_SpinPlayer(player_t *player, mobj_t *source, INT32 type, mobj_t *inflicto
static void K_RemoveGrowShrink(player_t *player) static void K_RemoveGrowShrink(player_t *player)
{ {
player->kartstuff[k_growshrinktimer] = 0;
player->kartstuff[k_growcancel] = 0;
if (player->mo && !P_MobjWasRemoved(player->mo)) if (player->mo && !P_MobjWasRemoved(player->mo))
{ {
if (player->kartstuff[k_growshrinktimer] > 0) // Play Shrink noise
S_StartSound(player->mo, sfx_kc59);
else if (player->kartstuff[k_growshrinktimer] < 0) // Play Grow noise
S_StartSound(player->mo, sfx_kc5a);
if (player->kartstuff[k_invincibilitytimer] == 0) if (player->kartstuff[k_invincibilitytimer] == 0)
player->mo->color = player->skincolor; player->mo->color = player->skincolor;
@ -2138,6 +2140,9 @@ static void K_RemoveGrowShrink(player_t *player)
player->mo->destscale = (6*player->mo->destscale)/8; player->mo->destscale = (6*player->mo->destscale)/8;
} }
player->kartstuff[k_growshrinktimer] = 0;
player->kartstuff[k_growcancel] = 0;
P_RestoreMusic(player); P_RestoreMusic(player);
} }
@ -3544,8 +3549,13 @@ static void K_DoShrink(player_t *user)
continue; continue;
if (players[i].kartstuff[k_position] < user->kartstuff[k_position]) if (players[i].kartstuff[k_position] < user->kartstuff[k_position])
{ {
//P_FlashPal(&players[i], PAL_NUKE, 10);
// Grow should get taken away.
if (players[i].kartstuff[k_growshrinktimer] > 0)
K_RemoveGrowShrink(&players[i]);
// Don't hit while invulnerable! // Don't hit while invulnerable!
if (!players[i].kartstuff[k_invincibilitytimer] else if (!players[i].kartstuff[k_invincibilitytimer]
&& players[i].kartstuff[k_growshrinktimer] <= 0 && players[i].kartstuff[k_growshrinktimer] <= 0
&& !players[i].kartstuff[k_hyudorotimer]) && !players[i].kartstuff[k_hyudorotimer])
{ {
@ -3559,15 +3569,9 @@ static void K_DoShrink(player_t *user)
players[i].mo->destscale = (6*mapobjectscale)/8; players[i].mo->destscale = (6*mapobjectscale)/8;
if (cv_kartdebugshrink.value && !modeattacking && !players[i].bot) if (cv_kartdebugshrink.value && !modeattacking && !players[i].bot)
players[i].mo->destscale = (6*players[i].mo->destscale)/8; players[i].mo->destscale = (6*players[i].mo->destscale)/8;
S_StartSound(players[i].mo, sfx_kc59);
} }
} }
// Grow should get taken away.
if (players[i].kartstuff[k_growshrinktimer] > 0)
K_RemoveGrowShrink(&players[i]);
//P_FlashPal(&players[i], PAL_NUKE, 10);
S_StartSound(players[i].mo, sfx_kc59);
} }
} }
} }
@ -5570,16 +5574,21 @@ void K_MoveKartPlayer(player_t *player, boolean onground)
if (ATTACK_IS_DOWN && !HOLDING_ITEM && NO_HYUDORO if (ATTACK_IS_DOWN && !HOLDING_ITEM && NO_HYUDORO
&& player->kartstuff[k_growshrinktimer] <= 0) // Grow holds the item box hostage && player->kartstuff[k_growshrinktimer] <= 0) // Grow holds the item box hostage
{ {
K_PlayPowerGloatSound(player->mo); if (player->kartstuff[k_growshrinktimer] < 0) // If you're shrunk, then "grow" will just make you normal again.
player->mo->scalespeed = mapobjectscale/TICRATE; K_RemoveGrowShrink(player);
player->mo->destscale = (3*mapobjectscale)/2; else
if (cv_kartdebugshrink.value && !modeattacking && !player->bot) {
player->mo->destscale = (6*player->mo->destscale)/8; K_PlayPowerGloatSound(player->mo);
player->kartstuff[k_growshrinktimer] = itemtime+(4*TICRATE); // 12 seconds player->mo->scalespeed = mapobjectscale/TICRATE;
P_RestoreMusic(player); player->mo->destscale = (3*mapobjectscale)/2;
if (!P_IsLocalPlayer(player)) if (cv_kartdebugshrink.value && !modeattacking && !player->bot)
S_StartSound(player->mo, (cv_kartinvinsfx.value ? sfx_alarmg : sfx_kgrow)); player->mo->destscale = (6*player->mo->destscale)/8;
S_StartSound(player->mo, sfx_kc5a); player->kartstuff[k_growshrinktimer] = itemtime+(4*TICRATE); // 12 seconds
P_RestoreMusic(player);
if (!P_IsLocalPlayer(player))
S_StartSound(player->mo, (cv_kartinvinsfx.value ? sfx_alarmg : sfx_kgrow));
S_StartSound(player->mo, sfx_kc5a);
}
player->kartstuff[k_itemamount]--; player->kartstuff[k_itemamount]--;
} }
break; break;