mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-14 22:00:50 +00:00
Mines can be punted
Setting behind leaves a longer startup animation window so that it can be punted more easily
This commit is contained in:
parent
4480a1c55a
commit
2f4d3eb087
4 changed files with 91 additions and 12 deletions
65
src/k_kart.c
65
src/k_kart.c
|
@ -2895,7 +2895,8 @@ static mobj_t *K_FindLastTrailMobj(player_t *player)
|
||||||
static mobj_t *K_ThrowKartItem(player_t *player, boolean missile, mobjtype_t mapthing, INT32 defaultDir, INT32 altthrow)
|
static mobj_t *K_ThrowKartItem(player_t *player, boolean missile, mobjtype_t mapthing, INT32 defaultDir, INT32 altthrow)
|
||||||
{
|
{
|
||||||
mobj_t *mo;
|
mobj_t *mo;
|
||||||
INT32 dir, PROJSPEED;
|
INT32 dir;
|
||||||
|
fixed_t PROJSPEED;
|
||||||
angle_t newangle;
|
angle_t newangle;
|
||||||
fixed_t newx, newy, newz;
|
fixed_t newx, newy, newz;
|
||||||
mobj_t *throwmo;
|
mobj_t *throwmo;
|
||||||
|
@ -3012,10 +3013,10 @@ static mobj_t *K_ThrowKartItem(player_t *player, boolean missile, mobjtype_t map
|
||||||
if (mo)
|
if (mo)
|
||||||
{
|
{
|
||||||
angle_t fa = player->mo->angle>>ANGLETOFINESHIFT;
|
angle_t fa = player->mo->angle>>ANGLETOFINESHIFT;
|
||||||
INT32 HEIGHT = (20 + (dir*10))*mapobjectscale + player->mo->momz;
|
fixed_t HEIGHT = (20 + (dir*10))*mapobjectscale + player->mo->momz;
|
||||||
|
|
||||||
mo->momx = player->mo->momx + FixedMul(FINECOSINE(fa), (altthrow == 2 ? 2*PROJSPEED/3 : PROJSPEED));
|
mo->momx = player->mo->momx + FixedMul(FINECOSINE(fa), PROJSPEED);
|
||||||
mo->momy = player->mo->momy + FixedMul(FINESINE(fa), (altthrow == 2 ? 2*PROJSPEED/3 : PROJSPEED));
|
mo->momy = player->mo->momy + FixedMul(FINESINE(fa), PROJSPEED);
|
||||||
mo->momz = P_MobjFlip(player->mo) * HEIGHT;
|
mo->momz = P_MobjFlip(player->mo) * HEIGHT;
|
||||||
|
|
||||||
if (player->mo->eflags & MFE_VERTICALFLIP)
|
if (player->mo->eflags & MFE_VERTICALFLIP)
|
||||||
|
@ -3082,12 +3083,68 @@ static mobj_t *K_ThrowKartItem(player_t *player, boolean missile, mobjtype_t map
|
||||||
|
|
||||||
if (player->mo->eflags & MFE_VERTICALFLIP)
|
if (player->mo->eflags & MFE_VERTICALFLIP)
|
||||||
mo->eflags |= MFE_VERTICALFLIP;
|
mo->eflags |= MFE_VERTICALFLIP;
|
||||||
|
|
||||||
|
if (mapthing == MT_SSMINE)
|
||||||
|
mo->extravalue1 = 14; // Pads the start-up length from 21 frames to a full second
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return mo;
|
return mo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void K_PuntMine(mobj_t *thismine, mobj_t *punter)
|
||||||
|
{
|
||||||
|
angle_t fa = R_PointToAngle2(0, 0, punter->momx, punter->momy) >> ANGLETOFINESHIFT;
|
||||||
|
fixed_t z = 30*mapobjectscale + punter->momz;
|
||||||
|
fixed_t spd;
|
||||||
|
mobj_t *mine;
|
||||||
|
|
||||||
|
if (!thismine || P_MobjWasRemoved(thismine))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (thismine->type == MT_SSMINE_SHIELD) // Create a new mine
|
||||||
|
{
|
||||||
|
mine = P_SpawnMobj(thismine->x, thismine->y, thismine->z, MT_SSMINE);
|
||||||
|
P_SetTarget(&mine->target, thismine->target);
|
||||||
|
mine->angle = thismine->angle;
|
||||||
|
mine->flags2 = thismine->flags2;
|
||||||
|
mine->floorz = thismine->floorz;
|
||||||
|
mine->ceilingz = thismine->ceilingz;
|
||||||
|
P_RemoveMobj(thismine);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
mine = thismine;
|
||||||
|
|
||||||
|
if (!mine || P_MobjWasRemoved(mine))
|
||||||
|
return;
|
||||||
|
|
||||||
|
switch (gamespeed)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
spd = 68*mapobjectscale; // Avg Speed is 34
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
spd = 96*mapobjectscale; // Avg Speed is 48
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
spd = 82*mapobjectscale; // Avg Speed is 41
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
mine->flags |= MF_NOCLIPTHING;
|
||||||
|
|
||||||
|
P_SetMobjState(mine, S_SSMINE_AIR1);
|
||||||
|
mine->threshold = 10;
|
||||||
|
mine->extravalue1 = 0;
|
||||||
|
mine->reactiontime = mine->info->reactiontime;
|
||||||
|
|
||||||
|
mine->momx = punter->momx + FixedMul(FINECOSINE(fa), spd);
|
||||||
|
mine->momy = punter->momy + FixedMul(FINESINE(fa), spd);
|
||||||
|
mine->momz = P_MobjFlip(mine) * z;
|
||||||
|
|
||||||
|
mine->flags &= ~MF_NOCLIPTHING;
|
||||||
|
}
|
||||||
|
|
||||||
#define THUNDERRADIUS 320
|
#define THUNDERRADIUS 320
|
||||||
|
|
||||||
static void K_DoThunderShield(player_t *player)
|
static void K_DoThunderShield(player_t *player)
|
||||||
|
|
|
@ -41,6 +41,7 @@ void K_SpawnBoostTrail(player_t *player);
|
||||||
void K_SpawnSparkleTrail(mobj_t *mo);
|
void K_SpawnSparkleTrail(mobj_t *mo);
|
||||||
void K_SpawnWipeoutTrail(mobj_t *mo, boolean translucent);
|
void K_SpawnWipeoutTrail(mobj_t *mo, boolean translucent);
|
||||||
void K_DriftDustHandling(mobj_t *spawner);
|
void K_DriftDustHandling(mobj_t *spawner);
|
||||||
|
void K_PuntMine(mobj_t *mine, mobj_t *punter);
|
||||||
void K_DoSneaker(player_t *player, INT32 type);
|
void K_DoSneaker(player_t *player, INT32 type);
|
||||||
void K_DoPogoSpring(mobj_t *mo, fixed_t vertispeed, UINT8 sound);
|
void K_DoPogoSpring(mobj_t *mo, fixed_t vertispeed, UINT8 sound);
|
||||||
void K_KillBananaChain(mobj_t *banana, mobj_t *inflictor, mobj_t *source);
|
void K_KillBananaChain(mobj_t *banana, mobj_t *inflictor, mobj_t *source);
|
||||||
|
|
10
src/p_map.c
10
src/p_map.c
|
@ -980,7 +980,12 @@ static boolean PIT_CheckThing(mobj_t *thing)
|
||||||
|
|
||||||
if (thing->type == MT_PLAYER)
|
if (thing->type == MT_PLAYER)
|
||||||
{
|
{
|
||||||
|
// Bomb punting
|
||||||
|
if ((tmthing->state >= &states[S_SSMINE1] && tmthing->state <= &states[S_SSMINE4])
|
||||||
|
|| (tmthing->state >= &states[S_SSMINE_DEPLOY8] && tmthing->state <= &states[S_SSMINE_DEPLOY13]))
|
||||||
P_KillMobj(tmthing, thing, thing);
|
P_KillMobj(tmthing, thing, thing);
|
||||||
|
else
|
||||||
|
K_PuntMine(tmthing, thing);
|
||||||
}
|
}
|
||||||
else if (thing->type == MT_ORBINAUT || thing->type == MT_JAWZ || thing->type == MT_JAWZ_DUD
|
else if (thing->type == MT_ORBINAUT || thing->type == MT_JAWZ || thing->type == MT_JAWZ_DUD
|
||||||
|| thing->type == MT_ORBINAUT_SHIELD || thing->type == MT_JAWZ_SHIELD)
|
|| thing->type == MT_ORBINAUT_SHIELD || thing->type == MT_JAWZ_SHIELD)
|
||||||
|
@ -1079,7 +1084,12 @@ static boolean PIT_CheckThing(mobj_t *thing)
|
||||||
if (tmthing->health <= 0 || thing->health <= 0)
|
if (tmthing->health <= 0 || thing->health <= 0)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
// Bomb punting
|
||||||
|
if ((thing->state >= &states[S_SSMINE1] && thing->state <= &states[S_SSMINE4])
|
||||||
|
|| (thing->state >= &states[S_SSMINE_DEPLOY8] && thing->state <= &states[S_SSMINE_DEPLOY13]))
|
||||||
P_KillMobj(thing, tmthing, tmthing);
|
P_KillMobj(thing, tmthing, tmthing);
|
||||||
|
else
|
||||||
|
K_PuntMine(thing, tmthing);
|
||||||
}
|
}
|
||||||
else if (thing->type == MT_MINEEXPLOSION && tmthing->player)
|
else if (thing->type == MT_MINEEXPLOSION && tmthing->player)
|
||||||
{
|
{
|
||||||
|
|
11
src/p_mobj.c
11
src/p_mobj.c
|
@ -8190,12 +8190,19 @@ void P_MobjThinker(mobj_t *mobj)
|
||||||
mobj->color = mobj->target->player->skincolor;
|
mobj->color = mobj->target->player->skincolor;
|
||||||
else
|
else
|
||||||
mobj->color = SKINCOLOR_KETCHUP;
|
mobj->color = SKINCOLOR_KETCHUP;
|
||||||
|
|
||||||
if (mobj->momx || mobj->momy)
|
if (mobj->momx || mobj->momy)
|
||||||
P_SpawnGhostMobj(mobj);
|
P_SpawnGhostMobj(mobj);
|
||||||
|
|
||||||
if (P_IsObjectOnGround(mobj))
|
if (P_IsObjectOnGround(mobj))
|
||||||
|
{
|
||||||
|
if (mobj->extravalue1 > 0)
|
||||||
|
mobj->extravalue1--;
|
||||||
|
else
|
||||||
{
|
{
|
||||||
if (mobj->state == &states[S_SSMINE_AIR1] || mobj->state == &states[S_SSMINE_AIR2])
|
if (mobj->state == &states[S_SSMINE_AIR1] || mobj->state == &states[S_SSMINE_AIR2])
|
||||||
P_SetMobjState(mobj, S_SSMINE_DEPLOY1);
|
P_SetMobjState(mobj, S_SSMINE_DEPLOY1);
|
||||||
|
|
||||||
if (mobj->reactiontime >= mobj->info->reactiontime)
|
if (mobj->reactiontime >= mobj->info->reactiontime)
|
||||||
{
|
{
|
||||||
mobj->momx = mobj->momy = 0;
|
mobj->momx = mobj->momy = 0;
|
||||||
|
@ -8203,15 +8210,19 @@ void P_MobjThinker(mobj_t *mobj)
|
||||||
mobj->reactiontime--;
|
mobj->reactiontime--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (mobj->reactiontime && mobj->reactiontime < mobj->info->reactiontime)
|
if (mobj->reactiontime && mobj->reactiontime < mobj->info->reactiontime)
|
||||||
{
|
{
|
||||||
mobj->reactiontime--;
|
mobj->reactiontime--;
|
||||||
if (!mobj->reactiontime)
|
if (!mobj->reactiontime)
|
||||||
P_KillMobj(mobj, NULL, NULL);
|
P_KillMobj(mobj, NULL, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((mobj->state >= &states[S_SSMINE1] && mobj->state <= &states[S_SSMINE4])
|
if ((mobj->state >= &states[S_SSMINE1] && mobj->state <= &states[S_SSMINE4])
|
||||||
|| (mobj->state >= &states[S_SSMINE_DEPLOY8] && mobj->state <= &states[S_SSMINE_DEPLOY13]))
|
|| (mobj->state >= &states[S_SSMINE_DEPLOY8] && mobj->state <= &states[S_SSMINE_DEPLOY13]))
|
||||||
A_GrenadeRing(mobj);
|
A_GrenadeRing(mobj);
|
||||||
|
|
||||||
if (mobj->threshold > 0)
|
if (mobj->threshold > 0)
|
||||||
mobj->threshold--;
|
mobj->threshold--;
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue