From 2fe0555e3f9be0ce43808c8b99e8ea1dbff57328 Mon Sep 17 00:00:00 2001 From: Eidolon Date: Thu, 19 May 2022 21:03:58 -0500 Subject: [PATCH] Make character cursor framerate-independent --- src/m_menu.c | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/src/m_menu.c b/src/m_menu.c index 16f879a1..23653576 100644 --- a/src/m_menu.c +++ b/src/m_menu.c @@ -9141,12 +9141,13 @@ Update the maxplayers label... if (itemOn == 2 && i == setupm_pselect) { - static UINT8 cursorframe = 0; - if (skullAnimCounter % 4 == 0) - cursorframe++; - if (cursorframe > 7) - cursorframe = 0; - V_DrawFixedPatch(x< 7 * FRACUNIT) + cursorframe -= 7 * FRACUNIT; + + V_DrawFixedPatch(x<> FRACBITS) + 1), PU_CACHE), NULL); } x += incrwidth; @@ -9487,16 +9488,15 @@ static void M_DrawSetupMultiPlayerMenu(void) fixed_t scale = FRACUNIT/2; INT32 offx = 8, offy = 8; patch_t *cursor; - static UINT8 cursorframe = 0; + static fixed_t cursorframe = 0; patch_t *face; UINT8 *colmap; - if (skullAnimCounter % 4 == 0) - cursorframe++; - if (cursorframe > 7) - cursorframe = 0; + cursorframe += renderdeltatics / 4; + if (cursorframe > 7 * FRACUNIT) + cursorframe -= 7 * FRACUNIT; - cursor = W_CachePatchName(va("K_BHILI%d", cursorframe+1), PU_CACHE); + cursor = W_CachePatchName(va("K_BHILI%d", (cursorframe >> FRACBITS) + 1), PU_CACHE); if (col < 0) col += numskins;