PLACEHOLDER, DO NOT PUSH THIS COMMIT

This commit is contained in:
RedEnchilada 2015-05-15 10:23:53 -05:00
parent bd0b7829bb
commit b69678f1a6

View file

@ -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