From 6512d71e4e2c601d4bd5b2e966c6ddbf072ebdf7 Mon Sep 17 00:00:00 2001 From: NepDisk Date: Thu, 18 Sep 2025 15:58:30 -0400 Subject: [PATCH] Try to improve regular turns and drifts --- src/k_bot.cpp | 35 +++++++++++++++++++++++++++++++---- src/k_bot.h | 2 ++ src/k_kart.c | 2 +- src/k_kart.h | 1 + 4 files changed, 35 insertions(+), 5 deletions(-) diff --git a/src/k_bot.cpp b/src/k_bot.cpp index e0ca166a9..e0bd6915e 100644 --- a/src/k_bot.cpp +++ b/src/k_bot.cpp @@ -80,6 +80,8 @@ void K_DrawBotDebugger(const player_t *player) V_DrawThinString(x2, y+32, vflags|(bd->driftlockout ? V_ORANGEMAP : 0), va("driftlockout: %d", bd->driftlockout)); V_DrawThinString(x1, y+40, vflags, va("driftturn: %d", bd->driftturn)); V_DrawThinString(x2, y+40, vflags, va("drifttime: %d", bd->drifttime)); + V_DrawThinString(x1, y+48, vflags, va("preditionerror: %d", bd->predictionerror)); + V_DrawThinString(x2, y+48, vflags, va("forwardmove: %d", player->cmd.forwardmove)); } /*-------------------------------------------------- @@ -1063,7 +1065,7 @@ static void K_DrawPredictionDebug(botdata_t *bd, const player_t *player) // Calculates drift skill for a player based on ~~stats~~ difficulty. static fixed_t K_BotDetermineDriftSkill(const player_t *player) { - return FRACUNIT/8 + (FRACUNIT * player->botvars.difficulty) / DIFFICULTBOT; + return FixedMul(FRACUNIT/8 + (FRACUNIT * player->botvars.difficulty) / DIFFICULTBOT, K_GetKartGameSpeedScalar(gamespeed)); //return ((FRACUNIT * (player->kartspeed + player->kartweight)) / 18); } @@ -1224,6 +1226,8 @@ static INT32 K_HandleBotTrack(botdata_t *bd, const player_t *player, angle_t des moveangle = player->mo->angle; anglediff = AngleDeltaSigned(moveangle, destangle); + bd->predictionerror = std::min(destangle - moveangle, moveangle - destangle); + // line up for an incoming drift if (bd->driftstate == DRIFTSTATE_STARTING) { @@ -1293,6 +1297,23 @@ static INT32 K_HandleBotTrack(botdata_t *bd, const player_t *player, angle_t des bd->acceldown = true; bd->brakedown = false; + // Additional grip for turns. + if (player->speed > K_GetKartSpeed(player, false, false)/2)//35*FRACUNIT + { + const angle_t MAXERROR = ANGLE_45; + const angle_t MIDERROR = ANGLE_22h; + + if (bd->predictionerror > MAXERROR && bd->driftstate == DRIFTSTATE_AUTO) + { + bd->acceldown = false; + bd->brakedown = true; + } + else if (bd->predictionerror > MIDERROR && bd->driftstate == DRIFTSTATE_AUTO) + { + bd->brakedown = true; + } + } + if (dirdist <= rad && bd->driftstate != DRIFTSTATE_STARTING) // steer towards waypoints when starting drift { @@ -1656,12 +1677,15 @@ void K_BotTicker(const player_t *player) ps_bots[player - players].item = I_GetPreciseTime() - t; } + // Update turning quicker if we're moving at high speeds. + UINT8 turndelta = (player->speed > (7 * K_GetKartSpeed(player, false, false) / 4)) ? 2 : 1; + if (turnamt > 0) { // Count up if (bd->turnconfirm < BOTTURNCONFIRM) { - bd->turnconfirm++; + bd->turnconfirm += turndelta; } } else if (turnamt < 0) @@ -1669,7 +1693,7 @@ void K_BotTicker(const player_t *player) // Count down if (bd->turnconfirm > -BOTTURNCONFIRM) { - bd->turnconfirm--; + bd->turnconfirm -= turndelta; } } else @@ -1770,7 +1794,10 @@ void K_BuildBotTiccmd(player_t *player, ticcmd_t *cmd) } // BOT_STYLE_NORMAL is the only other style, so... - cmd->forwardmove = !!bd->acceldown * MAXPLMOVE - !!bd->brakedown * MAXPLMOVE/2; + SINT8 maxacceldown = (!!bd->acceldown * MAXPLMOVE); + SINT8 maxbrakedown = !!bd->brakedown * MAXPLMOVE/2; + + cmd->forwardmove = maxacceldown - maxbrakedown; if (bd->itemthrow != 0) { cmd->throwdir = bd->itemthrow * KART_FULLTURN; diff --git a/src/k_bot.h b/src/k_bot.h index b74722be0..bc370c218 100644 --- a/src/k_bot.h +++ b/src/k_bot.h @@ -98,6 +98,8 @@ struct botdata_t boolean itemwasdown; // last tic's item button SINT8 itemthrow; // throwdir INT16 turnamt; // turning + + angle_t predictionerror; // How bad is our momentum angle relative to where we're trying to go? }; // AVAILABLE FOR LUA diff --git a/src/k_kart.c b/src/k_kart.c index 8b9d98270..211371663 100644 --- a/src/k_kart.c +++ b/src/k_kart.c @@ -2514,7 +2514,7 @@ static void K_UpdateSlopeBoost(player_t *player) player->prevslopeboost = addedboost; } -static fixed_t K_BoostRescale(fixed_t value,fixed_t oldmin,fixed_t oldmax,fixed_t newmin,fixed_t newmax) +fixed_t K_BoostRescale(fixed_t value,fixed_t oldmin,fixed_t oldmax,fixed_t newmin,fixed_t newmax) { return newmin + FixedMul(FixedDiv(value-oldmin , oldmax-oldmin), newmax-newmin); } diff --git a/src/k_kart.h b/src/k_kart.h index c96fada84..3e9320fd2 100644 --- a/src/k_kart.h +++ b/src/k_kart.h @@ -331,6 +331,7 @@ INT32 K_CheckpointThreshold(boolean roundup); void K_UpdateMobjItemOverlay(mobj_t *part, SINT8 itemType, UINT8 itemCount); +fixed_t K_BoostRescale(fixed_t value,fixed_t oldmin,fixed_t oldmax,fixed_t newmin,fixed_t newmax); void K_DoBoost(player_t *player, fixed_t speedboost, fixed_t accelboost, boolean stack, boolean visible); void K_ClearBoost(player_t *player);