From 5ebc65a1fb19f86c2add664470108002a0078945 Mon Sep 17 00:00:00 2001 From: Mitchell Richters Date: Mon, 30 Mar 2020 23:42:50 +1100 Subject: [PATCH] SW: Refinements to new input code. - videoNextPage() moved to after restoring interpolations. - Properly use Q16.16 in as many places as possible. This fixes the angle/X-axis issues. - Remove unnecessary call to timerUpdate() in main loop, only needs calling once and is called by eventhandlers(). --- source/sw/src/draw.cpp | 7 ++-- source/sw/src/game.cpp | 46 +++++++++++++------------ source/sw/src/game.h | 2 +- source/sw/src/jplayer.cpp | 2 +- source/sw/src/jsector.cpp | 2 +- source/sw/src/player.cpp | 71 +++++++++++++++++++-------------------- source/sw/src/track.cpp | 14 ++++---- 7 files changed, 74 insertions(+), 70 deletions(-) diff --git a/source/sw/src/draw.cpp b/source/sw/src/draw.cpp index 2fd4e1a9d..2d06adcf8 100644 --- a/source/sw/src/draw.cpp +++ b/source/sw/src/draw.cpp @@ -2071,7 +2071,7 @@ drawscreen(PLAYERp pp) tx = tx + quake_x; ty = ty + quake_y; //tq16horiz = tq16horiz + fix16_from_int(quake_x); - tq16ang = fix16_from_int(NORM_ANGLE(fix16_to_int(tq16ang) + quake_ang)); + tq16ang = fix16_sadd(tq16ang, fix16_from_int(quake_ang)) & 0x7FFFFFF; if (pp->sop_remote) { @@ -2263,8 +2263,6 @@ drawscreen(PLAYERp pp) if (!M_Active()) SecretInfo(pp); - videoNextPage(); - #if SYNC_TEST SyncStatMessage(); #endif @@ -2276,6 +2274,9 @@ drawscreen(PLAYERp pp) short_restoreinterpolations(); // Stick at end of drawscreen PostDraw(); + + videoNextPage(); + DrawScreen = FALSE; } diff --git a/source/sw/src/game.cpp b/source/sw/src/game.cpp index 1717553b8..fc43dec88 100644 --- a/source/sw/src/game.cpp +++ b/source/sw/src/game.cpp @@ -289,6 +289,7 @@ void MenuLevel(void); void StatScreen(PLAYERp mpp); void InitRunLevel(void); void RunLevel(void); +void getinput(int playerNum); ///////////////////////////////////////////////////////////////////////////////////////////// static FILE *debug_fout = NULL; @@ -2526,8 +2527,6 @@ void InitRunLevel(void) StartAmbientSound(); } -void getinput(int playerNum); - void RunLevel(void) { InitRunLevel(); @@ -2573,8 +2572,6 @@ void RunLevel(void) localInput = {}; domovethings(); - - timerUpdate(); } } @@ -2979,8 +2976,8 @@ void getinput(int const playerNum) #define NORMALKEYMOVE 35 #define MAXVEL ((NORMALKEYMOVE*2)+10) #define MAXSVEL ((NORMALKEYMOVE*2)+10) -#define MAXANGVEL 100 -#define MAXHORIZVEL 128 +#define MAXANGVEL 1024 +#define MAXHORIZVEL 256 #define HORIZ_SPEED (16) #define SET_LOC_KEY(bits, sync_num, key_test) SET(bits, ((!!(key_test)) << (sync_num))) @@ -3080,6 +3077,7 @@ void getinput(int const playerNum) int const running = G_CheckAutorun(buttonMap.ButtonDown(gamefunc_Run)); int32_t turnamount; int32_t keymove; + constexpr int analogTurnAmount = (NORMALTURN << 1); constexpr int const analogExtent = 32767; // KEEPINSYNC sdlayer.cpp if (running) @@ -3114,7 +3112,7 @@ void getinput(int const playerNum) else { input.q16avel = fix16_sadd(input.q16avel, fix16_sdiv(fix16_from_int(info.mousex), fix16_from_int(32))); - input.q16avel = fix16_sadd(input.q16avel, fix16_from_int(info.dyaw / analogExtent * (turnamount << 1))); + input.q16avel = fix16_sadd(input.q16avel, fix16_from_int(info.dyaw / analogExtent * (analogTurnAmount << 1))); } if (mouseaim) @@ -3125,7 +3123,7 @@ void getinput(int const playerNum) if (!in_mouseflip) input.q16horz = -input.q16horz; - input.q16horz = fix16_ssub(input.q16horz, fix16_from_int(info.dpitch * turnamount / analogExtent)); + input.q16horz = fix16_ssub(input.q16horz, fix16_from_int(info.dpitch * analogTurnAmount / analogExtent)); input.svel -= info.dx * keymove / analogExtent; input.vel -= info.dz * keymove / analogExtent; @@ -3228,7 +3226,7 @@ void getinput(int const playerNum) if ((pp->cursectnum == tempsect) || (klabs(getflorzofslope(tempsect, x, y) - k) <= (4 << 8))) { - pp->q16horizoff += fix16_from_int((((j - k) * 160) >> 16)); + pp->q16horizoff = fix16_sadd(pp->q16horizoff, fix16_from_float(scaleAdjustmentToInterval(mulscale16((j - k), 160)))); } } } @@ -3238,22 +3236,28 @@ void getinput(int const playerNum) { // tilt when climbing but you can't even really tell it if (pp->q16horizoff < fix16_from_int(100)) - pp->q16horizoff += fix16_from_int((((100 - fix16_to_int(pp->q16horizoff)) >> 3) + 1)); + pp->q16horizoff = fix16_sadd(pp->q16horizoff, fix16_from_float(scaleAdjustmentToInterval(fix16_to_float(((fix16_from_int(100) - pp->q16horizoff) >> 3) + fix16_one)))); } else { // Make q16horizoff grow towards 0 since q16horizoff is not modified when // you're not on a slope if (pp->q16horizoff > 0) - pp->q16horizoff -= fix16_from_int(((fix16_to_int(pp->q16horizoff) >> 3) + 1)); - if (pp->q16horizoff < 0) - pp->q16horizoff += fix16_from_int((((fix16_to_int(-pp->q16horizoff)) >> 3) + 1)); + { + pp->q16horizoff = fix16_ssub(pp->q16horizoff, fix16_from_float(scaleAdjustmentToInterval(fix16_to_float((pp->q16horizoff >> 3) + fix16_one)))); + pp->q16horizoff = fix16_max(pp->q16horizoff, 0); + } + else if (pp->q16horizoff < 0) + { + pp->q16horizoff = fix16_sadd(pp->q16horizoff, fix16_from_float(scaleAdjustmentToInterval(fix16_to_float((-pp->q16horizoff >> 3) + fix16_one)))); + pp->q16horizoff = fix16_min(pp->q16horizoff, 0); + } } } if (input.q16horz) { - pp->q16horizbase += input.q16horz; + pp->q16horizbase = fix16_sadd(pp->q16horizbase, input.q16horz); SET(pp->Flags, PF_LOCK_HORIZ | PF_LOOKING); } @@ -3271,11 +3275,11 @@ void getinput(int const playerNum) // adjust pp->q16horiz negative if (TEST_SYNC_KEY(pp, SK_SNAP_DOWN)) - pp->q16horizbase -= fix16_from_int((HORIZ_SPEED/2)); + pp->q16horizbase = fix16_ssub(pp->q16horizbase, fix16_from_int((HORIZ_SPEED/2))); // adjust pp->q16horiz positive if (TEST_SYNC_KEY(pp, SK_SNAP_UP)) - pp->q16horizbase += fix16_from_int((HORIZ_SPEED/2)); + pp->q16horizbase = fix16_sadd(pp->q16horizbase, fix16_from_int((HORIZ_SPEED/2))); } @@ -3287,11 +3291,11 @@ void getinput(int const playerNum) // adjust pp->q16horiz negative if (TEST_SYNC_KEY(pp, SK_LOOK_DOWN)) - pp->q16horizbase -= fix16_from_int(HORIZ_SPEED); + pp->q16horizbase = fix16_ssub(pp->q16horizbase, fix16_from_int(HORIZ_SPEED)); // adjust pp->q16horiz positive if (TEST_SYNC_KEY(pp, SK_LOOK_UP)) - pp->q16horizbase += fix16_from_int(HORIZ_SPEED); + pp->q16horizbase = fix16_sadd(pp->q16horizbase, fix16_from_int(HORIZ_SPEED)); } @@ -3307,7 +3311,7 @@ void getinput(int const playerNum) for (i = 1; i; i--) { // this formula does not work for pp->q16horiz = 101-103 - pp->q16horizbase += fix16_from_int(25 - (fix16_to_int(pp->q16horizbase) >> 2)); + pp->q16horizbase = fix16_sadd(pp->q16horizbase, fix16_ssub(fix16_from_int(25), fix16_sdiv(pp->q16horizbase, fix16_from_int(4)))); } } else @@ -3324,9 +3328,9 @@ void getinput(int const playerNum) // bound adjust q16horizoff if (pp->q16horizbase + pp->q16horizoff < fix16_from_int(PLAYER_HORIZ_MIN)) - pp->q16horizoff = fix16_from_int(PLAYER_HORIZ_MIN) - pp->q16horizbase; + pp->q16horizoff = fix16_ssub(fix16_from_int(PLAYER_HORIZ_MIN), pp->q16horizbase); else if (pp->q16horizbase + pp->q16horizoff > fix16_from_int(PLAYER_HORIZ_MAX)) - pp->q16horizoff = fix16_from_int(PLAYER_HORIZ_MAX) - pp->q16horizbase; + pp->q16horizoff = fix16_ssub(fix16_from_int(PLAYER_HORIZ_MAX), pp->q16horizbase); // add base and offsets pp->q16horiz = fix16_clamp((pp->q16horizbase + pp->q16horizoff), fix16_from_int(PLAYER_HORIZ_MIN), fix16_from_int(PLAYER_HORIZ_MAX)); diff --git a/source/sw/src/game.h b/source/sw/src/game.h index 17e0b537f..d5bc2b397 100644 --- a/source/sw/src/game.h +++ b/source/sw/src/game.h @@ -1088,7 +1088,7 @@ struct PLAYERstruct int oldposx,oldposy,oldposz; int RevolveX, RevolveY; - short RevolveDeltaAng, RevolveAng; + fix16_t RevolveDeltaAng, RevolveAng; // under vars are for wading and swimming short PlayerSprite, PlayerUnderSprite; diff --git a/source/sw/src/jplayer.cpp b/source/sw/src/jplayer.cpp index 46e49508d..a16d603f3 100644 --- a/source/sw/src/jplayer.cpp +++ b/source/sw/src/jplayer.cpp @@ -650,7 +650,7 @@ void computergetinput(int snum, SW_PACKET *syn) // Below formula fails in certain cases //syn->q16avel = fix16_from_int(min(max((((daang+1024-damyang)&2047)-1024)>>1,-MAXANGVEL),MAXANGVEL)); //was 127 p->q16ang = fix16_from_int(daang); - syn->q16horz = fix16_from_int(min(max((zang-fix16_to_int(p->q16horiz))>>1,-PLAYER_HORIZ_MAX),PLAYER_HORIZ_MAX)); + syn->q16horz = fix16_clamp(fix16_sdiv(fix16_ssub(fix16_from_int(zang), p->q16horiz), fix16_from_int(2)), -fix16_from_int(PLAYER_HORIZ_MAX), fix16_from_int(PLAYER_HORIZ_MAX)); // Sets type of aiming, auto aim for bots syn->bits |= (1<oposx + mulscale16(pp->posx - pp->oposx, smoothratio); // ty = pp->oposy + mulscale16(pp->posy - pp->oposy, smoothratio); // tz = pp->oposz + mulscale16(pp->posz - pp->oposz, smoothratio); -// tpq16ang = pp->oq16ang + mulscale16(((pp->q16ang + fix16_from_int(1024) - pp->oq16ang) & 0x7FFFFFF) - fix16_from_int(1024), smoothratio); +// tpq16ang = pp->q16ang dist = 0x7fffffff; diff --git a/source/sw/src/player.cpp b/source/sw/src/player.cpp index bf6cc29f8..49ca1e24a 100644 --- a/source/sw/src/player.cpp +++ b/source/sw/src/player.cpp @@ -98,7 +98,7 @@ SWBOOL NightVision = FALSE; extern SWBOOL FinishedLevel; //#define PLAYER_TURN_SCALE (8) -#define PLAYER_TURN_SCALE (12) +#define PLAYER_TURN_SCALE (3) // the smaller the number the slower the going #define PLAYER_RUN_FRICTION (50000L) @@ -1539,7 +1539,7 @@ DoPlayerCrawlHeight(PLAYERp pp) void DoPlayerTurn(PLAYERp pp) { - short angvel; + fix16_t angvel; #define TURN_SHIFT 2 @@ -1558,7 +1558,7 @@ DoPlayerTurn(PLAYERp pp) // make the first turn in the clockwise direction // the rest will follow delta_ang = GetDeltaAngle(pp->turn180_target, fix16_to_int(pp->q16ang)); - pp->q16ang = fix16_from_int(NORM_ANGLE(fix16_to_int(pp->q16ang) + (labs(delta_ang) >> TURN_SHIFT))); + pp->q16ang = fix16_sadd(pp->q16ang, fix16_from_int((labs(delta_ang) >> TURN_SHIFT))) & 0x7FFFFFF; SET(pp->Flags, PF_TURN_180); } @@ -1574,7 +1574,7 @@ DoPlayerTurn(PLAYERp pp) short delta_ang; delta_ang = GetDeltaAngle(pp->turn180_target, fix16_to_int(pp->q16ang)); - pp->q16ang = fix16_from_int(NORM_ANGLE(fix16_to_int(pp->q16ang) + (delta_ang >> TURN_SHIFT))); + pp->q16ang = fix16_sadd(pp->q16ang, fix16_from_int((delta_ang >> TURN_SHIFT))) & 0x7FFFFFF; sprite[pp->PlayerSprite].ang = fix16_to_int(pp->q16ang); if (!Prediction) @@ -1595,15 +1595,14 @@ DoPlayerTurn(PLAYERp pp) return; } - angvel = fix16_to_int(pp->input.q16avel) * PLAYER_TURN_SCALE; + angvel = fix16_smul(pp->input.q16avel, fix16_from_int(PLAYER_TURN_SCALE)); if (angvel != 0) { // running is not handled here now - angvel += DIV4(angvel); + angvel = fix16_sdiv(angvel, fix16_from_int(4)); - pp->q16ang += fix16_from_int(DIV32(angvel * synctics)); - pp->q16ang = fix16_from_int(NORM_ANGLE(fix16_to_int(pp->q16ang))); + pp->q16ang = fix16_sadd(pp->q16ang, fix16_sdiv(fix16_smul(angvel, fix16_from_int(synctics)), fix16_from_int(32))) & 0x7FFFFFF; // update players sprite angle // NOTE: It's also updated in UpdatePlayerSprite, but needs to be @@ -1622,7 +1621,7 @@ DoPlayerTurn(PLAYERp pp) void DoPlayerTurnBoat(PLAYERp pp) { - int angvel; + fix16_t angvel; int angslide; SECTOR_OBJECTp sop = pp->sop; @@ -1634,18 +1633,18 @@ DoPlayerTurnBoat(PLAYERp pp) angslide = sop->drive_angslide; pp->drive_angvel = (pp->drive_angvel + (pp->drive_oangvel*(angslide-1)))/angslide; - angvel = pp->drive_angvel; + angvel = fix16_from_int(pp->drive_angvel); } else { - angvel = fix16_to_int(pp->input.q16avel) * PLAYER_TURN_SCALE; - angvel += angvel - DIV4(angvel); - angvel = DIV32(angvel * synctics); + angvel = fix16_smul(pp->input.q16avel, fix16_from_int(PLAYER_TURN_SCALE)); + angvel = fix16_sadd(angvel, fix16_ssub(angvel, fix16_sdiv(angvel, fix16_from_int(4)))); + angvel = fix16_sdiv(fix16_smul(angvel, fix16_from_int(synctics)), fix16_from_int(32)); } if (angvel != 0) { - pp->q16ang = fix16_from_int(NORM_ANGLE(fix16_to_int(pp->q16ang) + angvel)); + pp->q16ang = fix16_sadd(pp->q16ang, angvel) & 0x7FFFFFF; sprite[pp->PlayerSprite].ang = fix16_to_int(pp->q16ang); } } @@ -1653,7 +1652,7 @@ DoPlayerTurnBoat(PLAYERp pp) void DoPlayerTurnTank(PLAYERp pp, int z, int floor_dist) { - int angvel; + fix16_t angvel; SECTOR_OBJECTp sop = pp->sop; if (sop->drive_angspeed) @@ -1666,18 +1665,18 @@ DoPlayerTurnTank(PLAYERp pp, int z, int floor_dist) angslide = sop->drive_angslide; pp->drive_angvel = (pp->drive_angvel + (pp->drive_oangvel*(angslide-1)))/angslide; - angvel = pp->drive_angvel; + angvel = fix16_from_int(pp->drive_angvel); } else { - angvel = DIV8(fix16_to_int(pp->input.q16avel) * synctics); + angvel = fix16_sdiv(fix16_smul(pp->input.q16avel, fix16_from_int(synctics)), fix16_from_int(8)); } if (angvel != 0) { - if (MultiClipTurn(pp, NORM_ANGLE(fix16_to_int(pp->q16ang) + angvel), z, floor_dist)) + if (MultiClipTurn(pp, NORM_ANGLE(fix16_to_int(fix16_sadd(pp->q16ang, angvel))), z, floor_dist)) { - pp->q16ang = fix16_from_int(NORM_ANGLE(fix16_to_int(pp->q16ang) + angvel)); + pp->q16ang = fix16_sadd(pp->q16ang, angvel) & 0x7FFFFFF; sprite[pp->PlayerSprite].ang = fix16_to_int(pp->q16ang); } } @@ -1686,7 +1685,7 @@ DoPlayerTurnTank(PLAYERp pp, int z, int floor_dist) void DoPlayerTurnTankRect(PLAYERp pp, int *x, int *y, int *ox, int *oy) { - int angvel; + fix16_t angvel; SECTOR_OBJECTp sop = pp->sop; if (sop->drive_angspeed) @@ -1699,18 +1698,18 @@ DoPlayerTurnTankRect(PLAYERp pp, int *x, int *y, int *ox, int *oy) angslide = sop->drive_angslide; pp->drive_angvel = (pp->drive_angvel + (pp->drive_oangvel*(angslide-1)))/angslide; - angvel = pp->drive_angvel; + angvel = fix16_from_int(pp->drive_angvel); } else { - angvel = DIV8(fix16_to_int(pp->input.q16avel) * synctics); + angvel = fix16_sdiv(fix16_smul(pp->input.q16avel, fix16_from_int(synctics)), fix16_from_int(8)); } if (angvel != 0) { - if (RectClipTurn(pp, NORM_ANGLE(fix16_to_int(pp->q16ang) + angvel), x, y, ox, oy)) + if (RectClipTurn(pp, NORM_ANGLE(fix16_to_int(fix16_sadd(pp->q16ang, angvel))), x, y, ox, oy)) { - pp->q16ang = fix16_from_int(NORM_ANGLE(fix16_to_int(pp->q16ang) + angvel)); + pp->q16ang = fix16_sadd(pp->q16ang, angvel) & 0x7FFFFFF; sprite[pp->PlayerSprite].ang = fix16_to_int(pp->q16ang); } } @@ -1719,8 +1718,8 @@ DoPlayerTurnTankRect(PLAYERp pp, int *x, int *y, int *ox, int *oy) void DoPlayerTurnTurret(PLAYERp pp) { - int angvel; - short new_ang; + fix16_t angvel; + fix16_t new_ang; short diff; SECTOR_OBJECTp sop = pp->sop; SW_PACKET last_input; @@ -1748,32 +1747,32 @@ DoPlayerTurnTurret(PLAYERp pp) angslide = sop->drive_angslide; pp->drive_angvel = (pp->drive_angvel + (pp->drive_oangvel*(angslide-1)))/angslide; - angvel = pp->drive_angvel; + angvel = fix16_from_int(pp->drive_angvel); } else { - angvel = DIV4(fix16_to_int(pp->input.q16avel) * synctics); + angvel = fix16_sdiv(fix16_smul(pp->input.q16avel, fix16_from_int(synctics)), fix16_from_int(4)); } if (angvel != 0) { - new_ang = NORM_ANGLE(fix16_to_int(pp->q16ang) + angvel); + new_ang = fix16_sadd(pp->q16ang, angvel) & 0x7FFFFFF; if (sop->limit_ang_center >= 0) { - diff = GetDeltaAngle(new_ang, sop->limit_ang_center); + diff = GetDeltaAngle(fix16_to_int(new_ang), sop->limit_ang_center); if (labs(diff) >= sop->limit_ang_delta) { if (diff < 0) - new_ang = sop->limit_ang_center - sop->limit_ang_delta; + new_ang = fix16_from_int(sop->limit_ang_center - sop->limit_ang_delta); else - new_ang = sop->limit_ang_center + sop->limit_ang_delta; + new_ang = fix16_from_int(sop->limit_ang_center + sop->limit_ang_delta); } } - pp->q16ang = fix16_from_int(new_ang); + pp->q16ang = new_ang; sprite[pp->PlayerSprite].ang = fix16_to_int(pp->q16ang); } } @@ -6439,14 +6438,14 @@ DoPlayerDeathHoriz(PLAYERp pp, short target, short speed) { if (pp->q16horiz > fix16_from_int(target)) { - pp->q16horiz -= fix16_from_int(speed); + pp->q16horiz = fix16_ssub(pp->q16horiz, fix16_from_int(speed)); if (pp->q16horiz <= fix16_from_int(target)) pp->q16horiz = fix16_from_int(target); } if (pp->q16horiz < fix16_from_int(target)) { - pp->q16horiz += fix16_from_int(speed); + pp->q16horiz = fix16_sadd(pp->q16horiz, fix16_from_int(speed)); if (pp->q16horiz >= fix16_from_int(target)) pp->q16horiz = fix16_from_int(target); } @@ -6546,7 +6545,7 @@ void DoPlayerDeathFollowKiller(PLAYERp pp) ang2 = getangle(kp->x - pp->posx, kp->y - pp->posy); delta_ang = GetDeltaAngle(ang2, fix16_to_int(pp->q16ang)); - pp->q16ang = fix16_from_int(NORM_ANGLE(fix16_to_int(pp->q16ang) + (delta_ang >> 4))); + pp->q16ang = fix16_sadd(pp->q16ang, fix16_from_int((delta_ang >> 4))) & 0x7FFFFFF; } } } diff --git a/source/sw/src/track.cpp b/source/sw/src/track.cpp index bcc0c9c0e..fdbce8df3 100644 --- a/source/sw/src/track.cpp +++ b/source/sw/src/track.cpp @@ -788,7 +788,7 @@ SectorObjectSetupBounds(SECTOR_OBJECTp sop) if (pp->posx > xlow && pp->posx < xhigh && pp->posy > ylow && pp->posy < yhigh) { - pp->RevolveAng = fix16_to_int(pp->q16ang); + pp->RevolveAng = pp->q16ang; pp->RevolveX = pp->posx; pp->RevolveY = pp->posy; pp->RevolveDeltaAng = 0; @@ -1619,7 +1619,7 @@ MovePlayer(PLAYERp pp, SECTOR_OBJECTp sop, int nx, int ny) { SET(pp->Flags, PF_PLAYER_RIDING); - pp->RevolveAng = fix16_to_int(pp->q16ang); + pp->RevolveAng = pp->q16ang; pp->RevolveX = pp->posx; pp->RevolveY = pp->posy; @@ -1644,7 +1644,7 @@ MovePlayer(PLAYERp pp, SECTOR_OBJECTp sop, int nx, int ny) // save the current information so when Player stops // moving then you // know where he was last - pp->RevolveAng = fix16_to_int(pp->q16ang); + pp->RevolveAng = pp->q16ang; pp->RevolveX = pp->posx; pp->RevolveY = pp->posy; @@ -1660,13 +1660,13 @@ MovePlayer(PLAYERp pp, SECTOR_OBJECTp sop, int nx, int ny) pp->RevolveY += BOUND_4PIX(ny); // Last known angle is now adjusted by the delta angle - pp->RevolveAng = NORM_ANGLE(fix16_to_int(pp->q16ang) - pp->RevolveDeltaAng); + pp->RevolveAng = fix16_ssub(pp->q16ang, pp->RevolveDeltaAng) & 0x7FFFFFF; } // increment Players delta angle - pp->RevolveDeltaAng = NORM_ANGLE(pp->RevolveDeltaAng + GlobSpeedSO); + pp->RevolveDeltaAng = fix16_sadd(pp->RevolveDeltaAng, fix16_from_int(GlobSpeedSO)) & 0x7FFFFFF; - rotatepoint(*(vec2_t *)&sop->xmid, *(vec2_t *)&pp->RevolveX, pp->RevolveDeltaAng, (vec2_t *)&pp->posx); + rotatepoint(*(vec2_t *)&sop->xmid, *(vec2_t *)&pp->RevolveX, fix16_to_int(pp->RevolveDeltaAng), (vec2_t *)&pp->posx); // THIS WAS CAUSING PROLEMS!!!! // Sectors are still being manipulated so you can end up in a void (-1) sector @@ -1674,7 +1674,7 @@ MovePlayer(PLAYERp pp, SECTOR_OBJECTp sop, int nx, int ny) // New angle is formed by taking last known angle and // adjusting by the delta angle - pp->q16ang = fix16_from_int(NORM_ANGLE(pp->RevolveAng + pp->RevolveDeltaAng)); + pp->q16ang = fix16_sadd(pp->RevolveAng, pp->RevolveDeltaAng) & 0x7FFFFFF; UpdatePlayerSprite(pp); }