mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-15 06:01:09 +00:00
PLACEHOLDER, DO NOT PUSH THIS COMMIT
This commit is contained in:
parent
bd0b7829bb
commit
b69678f1a6
1 changed files with 19 additions and 4 deletions
23
src/p_mobj.c
23
src/p_mobj.c
|
@ -1437,7 +1437,8 @@ void P_XYMovement(mobj_t *mo)
|
||||||
|
|
||||||
oldslope = mo->standingslope;
|
oldslope = mo->standingslope;
|
||||||
}
|
}
|
||||||
}
|
} else if (P_IsObjectOnGround(mo))
|
||||||
|
predictedz = mo->z;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Pushables can break some blocks
|
// Pushables can break some blocks
|
||||||
|
@ -1447,7 +1448,6 @@ void P_XYMovement(mobj_t *mo)
|
||||||
if (!P_TryMove(mo, mo->x + xmove, mo->y + ymove, true) && !(mo->eflags & MFE_SPRUNG))
|
if (!P_TryMove(mo, mo->x + xmove, mo->y + ymove, true) && !(mo->eflags & MFE_SPRUNG))
|
||||||
{
|
{
|
||||||
// blocked move
|
// blocked move
|
||||||
|
|
||||||
if (player) {
|
if (player) {
|
||||||
moved = false;
|
moved = false;
|
||||||
if (player->bot)
|
if (player->bot)
|
||||||
|
@ -1562,6 +1562,8 @@ void P_XYMovement(mobj_t *mo)
|
||||||
|
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
if (moved && oldslope) { // Check to see if we ran off
|
if (moved && oldslope) { // Check to see if we ran off
|
||||||
|
//angle_t moveangle = R_PointToAngle2(mo->momx, mo->momy);
|
||||||
|
|
||||||
if (oldslope != mo->standingslope) { // First, compare different slopes
|
if (oldslope != mo->standingslope) { // First, compare different slopes
|
||||||
// Start by quantizing momentum on this slope
|
// Start by quantizing momentum on this slope
|
||||||
v3fixed_t test;
|
v3fixed_t test;
|
||||||
|
@ -1572,14 +1574,27 @@ void P_XYMovement(mobj_t *mo)
|
||||||
P_QuantizeMomentumToSlope(&test, mo->standingslope);
|
P_QuantizeMomentumToSlope(&test, mo->standingslope);
|
||||||
|
|
||||||
// Now compare the Zs of the different quantizations
|
// Now compare the Zs of the different quantizations
|
||||||
if (slopemom.z - test.z > 2*FRACUNIT) { // Allow for a bit of sticking - this value can be adjusted later
|
if (slopemom.z - test.z > P_AproxDistance(slopemom.x, slopemom.y/3) { // Allow for a bit of sticking - this value can be adjusted later
|
||||||
mo->standingslope = oldslope;
|
mo->standingslope = oldslope;
|
||||||
P_SlopeLaunch(mo);
|
P_SlopeLaunch(mo);
|
||||||
}
|
}
|
||||||
} else if (predictedz-mo->z > 2*FRACUNIT) { // Now check if we were supposed to stick to this slope
|
} else if (predictedz-mo->z > P_AproxDistance(slopemom.x, slopemom.y)/3) { // Now check if we were supposed to stick to this slope
|
||||||
mo->standingslope = oldslope;
|
mo->standingslope = oldslope;
|
||||||
P_SlopeLaunch(mo);
|
P_SlopeLaunch(mo);
|
||||||
}
|
}
|
||||||
|
} else if (moved && mo->standingslope && predictedz) {
|
||||||
|
slopemom.x = mo->momx;
|
||||||
|
slopemom.y = mo->momy;
|
||||||
|
slopemom.z = 0;
|
||||||
|
|
||||||
|
P_QuantizeMomentumToSlope(&slopemom, mo->standingslope);
|
||||||
|
|
||||||
|
if (-slopemom.z > P_AproxDistance(mo->momx, mo->momy)/3) {
|
||||||
|
mo->momz = P_MobjFlip(mo)*FRACUNIT/2;
|
||||||
|
mo->z = predictedz + P_MobjFlip(mo);
|
||||||
|
mo->standingslope = NULL;
|
||||||
|
CONS_Printf("Launched off of flat surface running into downward slope\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue