From e1a5e37126a5e94ce959a805f32b2cb7d086ec0d Mon Sep 17 00:00:00 2001 From: Mitchell Richters <mjr4077au@gmail.com> Date: Mon, 7 Sep 2020 21:50:43 +1000 Subject: [PATCH] - SW: Handle `DoPlayerTurn()`/`DoPlayerHorizon()` better while dead. --- source/sw/src/input.cpp | 4 +- source/sw/src/player.cpp | 194 ++++++++++++++++++++------------------- 2 files changed, 102 insertions(+), 96 deletions(-) diff --git a/source/sw/src/input.cpp b/source/sw/src/input.cpp index d3ecd25de..21c898192 100644 --- a/source/sw/src/input.cpp +++ b/source/sw/src/input.cpp @@ -278,9 +278,9 @@ static void processMovement(PLAYERp const pp, ControlInfo* const hidInput, bool if (!cl_syncinput) { if (TEST(pp->Flags2, PF2_INPUT_CAN_TURN)) - DoPlayerTurn(pp, !TEST(pp->Flags, PF_DEAD) || TEST(pp->Flags, PF_DEAD) && TEST(pp->Flags, PF_DEAD_HEAD|PF_HEAD_CONTROL) ? q16avel : 0, scaleAdjust); + DoPlayerTurn(pp, q16avel, scaleAdjust); if (TEST(pp->Flags2, PF2_INPUT_CAN_AIM)) - DoPlayerHorizon(pp, !TEST(pp->Flags, PF_DEAD) ? q16horz : 0, scaleAdjust); + DoPlayerHorizon(pp, q16horz, scaleAdjust); } loc.fvel = clamp(loc.fvel + fvel, -MAXFVEL, MAXFVEL); diff --git a/source/sw/src/player.cpp b/source/sw/src/player.cpp index 4a83201d1..445393749 100644 --- a/source/sw/src/player.cpp +++ b/source/sw/src/player.cpp @@ -1551,63 +1551,66 @@ DoPlayerCrawlHeight(PLAYERp pp) void DoPlayerTurn(PLAYERp pp, fixed_t const q16avel, double const scaleAdjust) { - if (!TEST(pp->Flags, PF_TURN_180)) + if (!TEST(pp->Flags, PF_DEAD) || TEST(pp->Flags, PF_DEAD) && TEST(pp->Flags, PF_DEAD_HEAD|PF_HEAD_CONTROL)) { - if (pp->input.actions & SB_TURNAROUND) + if (!TEST(pp->Flags, PF_TURN_180)) { - if (pp->KeyPressBits & SB_TURNAROUND) + if (pp->input.actions & SB_TURNAROUND) { - fixed_t delta_ang; + if (pp->KeyPressBits & SB_TURNAROUND) + { + fixed_t delta_ang; - pp->KeyPressBits &= ~SB_TURNAROUND; + pp->KeyPressBits &= ~SB_TURNAROUND; - pp->turn180_target = pp->q16ang + IntToFixed(1024); + pp->turn180_target = pp->q16ang + IntToFixed(1024); - // make the first turn in the clockwise direction - // the rest will follow - delta_ang = labs(GetDeltaQ16Angle(pp->turn180_target, pp->q16ang)) >> TURN_SHIFT; - pp->q16ang = (pp->q16ang + xs_CRoundToInt(scaleAdjust * delta_ang)) & 0x7FFFFFF; + // make the first turn in the clockwise direction + // the rest will follow + delta_ang = labs(GetDeltaQ16Angle(pp->turn180_target, pp->q16ang)) >> TURN_SHIFT; + pp->q16ang = (pp->q16ang + xs_CRoundToInt(scaleAdjust * delta_ang)) & 0x7FFFFFF; - SET(pp->Flags, PF_TURN_180); + SET(pp->Flags, PF_TURN_180); + } + } + else + { + pp->KeyPressBits |= SB_TURNAROUND; } } - else + + if (TEST(pp->Flags, PF_TURN_180)) { - pp->KeyPressBits |= SB_TURNAROUND; - } - } + fixed_t delta_ang; - if (TEST(pp->Flags, PF_TURN_180)) - { - fixed_t delta_ang; + delta_ang = GetDeltaQ16Angle(pp->turn180_target, pp->q16ang) >> TURN_SHIFT; + pp->q16ang = (pp->q16ang + xs_CRoundToInt(scaleAdjust * delta_ang)) & 0x7FFFFFF; - delta_ang = GetDeltaQ16Angle(pp->turn180_target, pp->q16ang) >> TURN_SHIFT; - pp->q16ang = (pp->q16ang + xs_CRoundToInt(scaleAdjust * delta_ang)) & 0x7FFFFFF; + sprite[pp->PlayerSprite].ang = FixedToInt(pp->q16ang); - sprite[pp->PlayerSprite].ang = FixedToInt(pp->q16ang); + if (!Prediction && pp->PlayerUnderSprite >= 0) + { + sprite[pp->PlayerUnderSprite].ang = FixedToInt(pp->q16ang); + } - if (!Prediction && pp->PlayerUnderSprite >= 0) - { - sprite[pp->PlayerUnderSprite].ang = FixedToInt(pp->q16ang); + // get new delta to see how close we are + delta_ang = GetDeltaQ16Angle(pp->turn180_target, pp->q16ang); + + if (labs(delta_ang) < (IntToFixed(3) << TURN_SHIFT)) + { + pp->q16ang = pp->turn180_target; + RESET(pp->Flags, PF_TURN_180); + } + else + { + return; + } } - // get new delta to see how close we are - delta_ang = GetDeltaQ16Angle(pp->turn180_target, pp->q16ang); - - if (labs(delta_ang) < (IntToFixed(3) << TURN_SHIFT)) + if (q16avel != 0) { - pp->q16ang = pp->turn180_target; - RESET(pp->Flags, PF_TURN_180); + pp->q16ang = (pp->q16ang + q16avel) & 0x7FFFFFF; } - else - { - return; - } - } - - if (q16avel != 0) - { - pp->q16ang = (pp->q16ang + q16avel) & 0x7FFFFFF; } if (!cl_syncinput && pp->angAdjust) @@ -1859,67 +1862,70 @@ PlayerAutoLook(PLAYERp pp, double const scaleAdjust) void DoPlayerHorizon(PLAYERp pp, fixed_t const q16horz, double const scaleAdjust) { - // Fixme: This should probably be made optional. - if (cl_slopetilting) - PlayerAutoLook(pp, scaleAdjust); - - if (q16horz) + if (!TEST(pp->Flags, PF_DEAD)) { - pp->q16horizbase += q16horz; - SET(pp->Flags, PF_LOCK_HORIZ | PF_LOOKING); - } + // Fixme: This should probably be made optional. + if (cl_slopetilting) + PlayerAutoLook(pp, scaleAdjust); - // this is the locked type - if (pp->input.actions & (SB_AIM_UP|SB_AIM_DOWN)) - { - // set looking because player is manually looking. - SET(pp->Flags, PF_LOCK_HORIZ | PF_LOOKING); - - // adjust q16horiz negative - if (pp->input.actions & SB_AIM_DOWN) - pp->q16horizbase -= FloatToFixed(scaleAdjust * (HORIZ_SPEED >> 1)); - - // adjust q16horiz positive - if (pp->input.actions & SB_AIM_UP) - pp->q16horizbase += FloatToFixed(scaleAdjust * (HORIZ_SPEED >> 1)); - } - - // this is the unlocked type - if (pp->input.actions & (SB_LOOK_UP|SB_LOOK_DOWN|SB_CENTERVIEW)) - { - RESET(pp->Flags, PF_LOCK_HORIZ); - SET(pp->Flags, PF_LOOKING); - - // adjust q16horiz negative - if (pp->input.actions & SB_LOOK_DOWN) - pp->q16horizbase -= FloatToFixed(scaleAdjust * HORIZ_SPEED); - - // adjust q16horiz positive - if (pp->input.actions & SB_LOOK_UP) - pp->q16horizbase += FloatToFixed(scaleAdjust * HORIZ_SPEED); - - if (pp->input.actions & SB_CENTERVIEW) - pp->q16horizoff = 0; - } - - if (!TEST(pp->Flags, PF_LOCK_HORIZ)) - { - if (!(pp->input.actions & (SB_LOOK_UP|SB_LOOK_DOWN))) + if (q16horz) { - // not pressing the q16horiz keys - if (pp->q16horizbase != IntToFixed(100)) + pp->q16horizbase += q16horz; + SET(pp->Flags, PF_LOCK_HORIZ | PF_LOOKING); + } + + // this is the locked type + if (pp->input.actions & (SB_AIM_UP|SB_AIM_DOWN)) + { + // set looking because player is manually looking. + SET(pp->Flags, PF_LOCK_HORIZ | PF_LOOKING); + + // adjust q16horiz negative + if (pp->input.actions & SB_AIM_DOWN) + pp->q16horizbase -= FloatToFixed(scaleAdjust * (HORIZ_SPEED >> 1)); + + // adjust q16horiz positive + if (pp->input.actions & SB_AIM_UP) + pp->q16horizbase += FloatToFixed(scaleAdjust * (HORIZ_SPEED >> 1)); + } + + // this is the unlocked type + if (pp->input.actions & (SB_LOOK_UP|SB_LOOK_DOWN|SB_CENTERVIEW)) + { + RESET(pp->Flags, PF_LOCK_HORIZ); + SET(pp->Flags, PF_LOOKING); + + // adjust q16horiz negative + if (pp->input.actions & SB_LOOK_DOWN) + pp->q16horizbase -= FloatToFixed(scaleAdjust * HORIZ_SPEED); + + // adjust q16horiz positive + if (pp->input.actions & SB_LOOK_UP) + pp->q16horizbase += FloatToFixed(scaleAdjust * HORIZ_SPEED); + + if (pp->input.actions & SB_CENTERVIEW) + pp->q16horizoff = 0; + } + + if (!TEST(pp->Flags, PF_LOCK_HORIZ)) + { + if (!(pp->input.actions & (SB_LOOK_UP|SB_LOOK_DOWN))) { - // move q16horiz back to 100 - for (int i = 1; i; i--) + // not pressing the q16horiz keys + if (pp->q16horizbase != IntToFixed(100)) { - // this formula does not work for q16horiz = 101-103 - pp->q16horizbase += xs_CRoundToInt(scaleAdjust * (IntToFixed(25) - (pp->q16horizbase >> 2))); + // move q16horiz back to 100 + for (int i = 1; i; i--) + { + // this formula does not work for q16horiz = 101-103 + pp->q16horizbase += xs_CRoundToInt(scaleAdjust * (IntToFixed(25) - (pp->q16horizbase >> 2))); + } + } + else + { + // not looking anymore because q16horiz is back at 100 + RESET(pp->Flags, PF_LOOKING); } - } - else - { - // not looking anymore because q16horiz is back at 100 - RESET(pp->Flags, PF_LOOKING); } } }