3#include "game/kart/KartBoost.hh"
4#include "game/kart/KartBurnout.hh"
5#include "game/kart/KartHalfPipe.hh"
6#include "game/kart/KartObjectProxy.hh"
7#include "game/kart/KartReject.hh"
8#include "game/kart/KartState.hh"
10#include "game/field/CourseColMgr.hh"
12#include <egg/core/BitFlag.hh>
31 virtual void createSubsystems();
33 virtual void calcWheelie() {}
34 virtual void setTurnParams();
35 virtual void init(
bool b1,
bool b2);
39 [[nodiscard]]
virtual f32 leanRot()
const {
47 void calcRespawnStart();
49 void calcRespawnBoost();
54 void calcStickyRoad();
66 void clearRampBoost();
67 void clearZipperBoost();
70 void clearOffroadInvincibility();
71 void clearRejectRoad();
84 void calcHopPhysics();
85 void calcRejectRoad();
88 Field::KCLTypeMask *maskOut, Field::KCLTypeMask flags)
const;
92 virtual void onHop() {}
93 virtual void onWallCollision() {}
95 virtual void initOob() {}
105 virtual bool canWheelie()
const {
110 virtual bool canHop()
const {
111 if (!state()->isHopStart() || !state()->isTouchingGround()) {
115 if (state()->isInAction()) {
123 bool canStartDrift()
const {
124 constexpr f32 MINIMUM_DRIFT_THRESOLD = 0.55f;
129 void tryStartBoostPanel();
132 void tryEndJumpPad();
133 void cancelJumpPad();
135 void activateBoost(KartBoost::Type type, s16 frames);
136 void applyStartBoost(s16 frames);
137 void activateMushroom();
138 void activateZipperBoost();
142 void calcZipperBoost();
150 void triggerRespawn();
153 void setSpeed(f32 val) {
173 void setFloorCollisionCount(
u16 count) {
177 void setKCLWheelSpeedFactor(f32 val) {
181 void setKCLWheelRotFactor(f32 val) {
186 void setKartSpeedLimit() {
187 constexpr f32 LIMIT = 120.0f;
201 [[nodiscard]] f32 softSpeedLimit()
const {
205 [[nodiscard]] f32 speed()
const {
209 [[nodiscard]] f32 acceleration()
const {
217 [[nodiscard]] f32 hardSpeedLimit()
const {
229 [[nodiscard]] f32 totalScale()
const {
233 [[nodiscard]] f32 hitboxScale()
const {
234 return m_hitboxScale;
249 [[nodiscard]] f32 speedRatioCapped()
const {
253 [[nodiscard]] f32 speedRatio()
const {
257 [[nodiscard]]
u16 floorCollisionCount()
const {
261 [[nodiscard]] s32 hopStickX()
const {
265 [[nodiscard]] f32 hopPosY()
const {
269 [[nodiscard]] s16 respawnTimer()
const {
270 return m_respawnTimer;
273 [[nodiscard]] s16 respawnPostLandTimer()
const {
277 [[nodiscard]] PadType &padType() {
281 [[nodiscard]] KartJump *jump()
const {
285 [[nodiscard]] KartHalfPipe *halfPipe()
const {
289 [[nodiscard]] KartBurnout &burnout() {
306 enum class DriftState {
331 f32 stabilizationFactor;
351 bool m_hasLandingDir;
367 f32 m_standStillBoostRot;
368 DriftState m_driftState;
373 s16 m_zipperBoostTimer;
374 s16 m_zipperBoostMax;
386 u32 m_nonZipperAirtime;
388 f32 m_jumpPadMaxSpeed;
391 f32 m_autoDriftAngle;
392 s16 m_autoDriftStartFrameCounter;
393 f32 m_cannonEntryOfsLength;
424 f32 leanRotShallowFactor;
427 f32 driftStickXFactor;
430 f32 leanRotIncCountdown;
431 f32 leanRotCapCountdown;
434 f32 leanRotDecayFactor;
435 u16 maxWheelieFrames;
444 void createSubsystems()
override;
447 void onHop()
override;
450 void initOob()
override;
452 void init(
bool b1,
bool b2)
override;
453 void clear()
override;
459 constexpr f32 WHEELIE_SPEED_BONUS = 0.15f;
460 return state()->isWheelie() ? WHEELIE_SPEED_BONUS : 0.0f;
464 [[nodiscard]] f32 wheelieRotFactor()
const {
465 constexpr f32 WHEELIE_ROTATION_FACTOR = 0.2f;
467 return state()->isWheelie() ? WHEELIE_ROTATION_FACTOR : 1.0f;
474 [[nodiscard]] f32 leanRot()
const override {
481 constexpr f32 WHEELIE_THRESHOLD = 0.3f;
497 s16 m_autoHardStickXFrames;
State management for boosts (start boost, mushrooms, mini-turbos)
Calculates the duration of burnout and rotation induced when holding acceleration too long during the...
Handles the physics and boosts associated with zippers.
Manages trick inputs and state.
Responsible for reacting to player inputs and moving the bike.
f32 m_leanRot
Z-axis rotation of the bike from leaning.
f32 m_leanRotCap
The maximum leaning rotation.
void calcWheelie() override
STAGE 1+ - Every frame, checks player input for wheelies and computes wheelie rotation.
void calcMtCharge() override
Every frame during a drift, calculates MT charge based on player input.
virtual void startWheelie()
STAGE 1+ - Sets the wheelie bit flag and some wheelie-related variables.
f32 m_wheelieRotDec
The wheelie rotation decrementor, used after a wheelie has ended.
u32 m_wheelieFrames
Tracks wheelie duration and cancels the wheelie after 180 frames.
f32 m_wheelieRot
X-axis rotation from wheeling.
const TurningParameters * m_turningParams
Inside/outside drifting bike turn info.
void setTurnParams() override
On init, sets the bike's lean rotation cap and increment.In addition to setting the lean rotation cap...
f32 m_maxWheelieRot
The maximum wheelie rotation.
void tryStartWheelie()
STAGE 1+ - Every frame, checks player input to see if we should start or stop a wheelie.
void onWallCollision() override
Called when you collide with a wall. All it does for bikes is cancel wheelies.
void onHop() override
Virtual function that just cancels wheelies when you hop.
f32 getWheelieSoftSpeedLimitBonus() const override
Returns what % to raise the speed cap when wheeling.
bool canWheelie() const override
Checks if the kart is going fast enough to wheelie.
void calcVehicleRotation(f32) override
Every frame, calculates rotation, EV, and angular velocity for the bike.
s16 m_wheelieCooldown
The number of frames before another wheelie can start.
f32 m_leanRotInc
The incrementor for leaning rotation.
virtual void cancelWheelie()
Clears the wheelie bit flag and resets the rotation decrement.
Responsible for reacting to player inputs and moving the kart.
f32 m_baseSpeed
The speed associated with the current character/vehicle stats.
void calcRotation()
Every frame, calculates kart rotation based on player input.
s16 m_ssmtLeewayTimer
Frames to forgive letting go of A before clearing SSMT charge.
s32 m_hopFrame
A timer that can prevent subsequent hops until reset.
void calcDisableBackwardsAccel()
Computes the current cooldown duration between braking and reversing.
EGG::Vector3f m_hopUp
The up vector when hopping.
u16 m_mushroomBoostTimer
Number of frames until the mushroom boost runs out.
void calcSpecialFloor()
Every frame, calculates any boost resulting from a boost panel.
void calcWallCollisionStart(f32 param_2)
If we started to collide with a wall this frame, applies rotation.
KartHalfPipe * m_halfPipe
Pertains to zipper physics.
f32 m_kclRotFactor
Float between 0-1 that scales the player's turning radius on offroad.
f32 m_outsideDriftBonus
Added to angular velocity when outside drifting.
void tryStartBoostRamp()
Sets offroad invincibility and and enables the ramp boost bitfield flag.
u16 m_smtCharge
A value between 0 and 300 representing current SMT charge.
f32 m_speedRatio
The ratio between current speed and the player's base speed stat.
@ DriftReset
Set when a wall bonk should cancel your drift.
@ SsmtCharged
Set after holding a stand-still mini-turbo for 75 frames.
@ TrickableSurface
Set when driving on a trickable surface.
@ SsmtLeeway
If set, activates SSMT when not pressing A or B.
@ WallBounce
Set when our speed loss from wall collision is > 30.0f.
@ Respawned
Set when Lakitu lets go of the player, cleared when landing.
void tryStartJumpPad()
Applies calculations to start interacting with a jump pad.
f32 m_jumpPadMinSpeed
Snaps the player to a minimum speed when first touching a jump pad.
f32 m_hopPosY
Relative position as the result of a hop. Starts at 0.
DrivingDirection m_drivingDirection
Current state of driver's direction.
bool calcPreDrift()
Each frame, checks for hop or slipdrift. Computes drift direction based on player input.
f32 m_speed
Current speed, restricted to the soft speed limit.
s16 m_offroadInvincibility
How many frames until the player is affected by offroad.
void calcAirtimeTop()
Calculates rotation of the bike due to excessive airtime.
void startManualDrift()
Called when the player lands from a drift hop, or to start a slipdrift.
void controlOutsideDriftAngle()
Every frame, handles mini-turbo charging and outside drifting bike rotation.
f32 m_softSpeedLimit
Base speed + boosts + wheelies, restricted to the hard speed limit.
virtual void hop()
Initializes hop information, resets upwards EV and clears upwards force.
void calcStandstillBoostRot()
STAGE Computes the x-component of angular velocity based on the kart's speed.
EGG::Vector3f m_outsideDriftLastDir
Used to compute the next m_outsideDriftAngle.
void calcManualDrift()
Each frame, handles hopping, drifting, and mini-turbos.
virtual void calcMtCharge()
Every frame during a drift, calculates MT/SMT charge based on player input.
void calcSsmt()
Calculates standstill mini-turbo components, if applicable.
void calcAcceleration()
Every frame, applies acceleration to the kart's internal velocity.
f32 m_processedSpeed
Offset 0x28. It's only ever just a copy of m_speed.
void releaseMt()
Stops charging a mini-turbo, and applies boost if charged.
f32 m_kclSpeedFactor
Float between 0-1 that scales the player's speed on offroad.
f32 m_weightedTurn
Magnitude+direction of stick input, factoring in the kart's stats.
void calcVehicleSpeed()
Every frame, computes speed based on acceleration and any active boosts.
f32 m_lastSpeed
Last frame's speed, cached to calculate angular velocity.
s16 m_ssmtDisableAccelTimer
Counter that tracks delay before starting to reverse.
void calcOffroadInvincibility()
Checks a timer to see if we are still ignoring offroad slowdown.
KartBurnout m_burnout
Manages the state of start boost burnout.
f32 calcVehicleAcceleration() const
Every frame, computes acceleration based off the character/vehicle stats.
void calcAutoDrift()
Each frame, handles automatic transmission drifting.
f32 m_realTurn
The "true" turn magnitude. Equal to m_weightedTurn unless drifting.
const DriftingParameters * m_driftingParams
Drift-type-specific parameters.
void calc()
Each frame, calculates the kart's movement.
EGG::Vector3f m_up
Vector perpendicular to the floor, pointing upwards.
s16 m_ssmtCharge
Increments every frame up to 75 when charging stand-still MT.
f32 m_speedDragMultiplier
After 5 frames of airtime, this causes speed to slowly decay.
u16 m_mtCharge
A value between 0 and 270 representing current MT charge.
void calcSsmtStart()
Calculates whether we are starting a standstill mini-turbo.
s16 m_respawnPostLandTimer
Counts up to 4 if not accelerating after respawn landing.
virtual f32 getWheelieSoftSpeedLimitBonus() const
Returns the % speed boost from wheelies. For karts, this is always 0.
f32 m_kclWheelRotFactor
The slowest rotation multiplier of each wheel's floor collision.
void resetDriftManual()
Clears drift state. Called when touching ground and drift is canceled.
f32 m_totalScale
[Unused] Always 1.0f
f32 m_acceleration
Captures the acceleration from player input and boosts.
virtual void calcVehicleRotation(f32 turn)
Every frame, calculates rotation, EV, and angular velocity for the kart.
s16 m_respawnPreLandTimer
Counts down from 4 when pressing A before landing from respawn.
virtual void calcTurn()
Each frame, looks at player input and kart stats. Saves turn-related info.
f32 m_divingRot
Induces x-axis angular velocity based on up/down stick input.
f32 m_outsideDriftAngle
The facing angle of an outward-drifting vehicle.
EGG::Vector3f m_lastDir
m_speed from the previous frame but with signed magnitude.
EGG::Vector3f m_smoothedUp
A smoothed up vector, mostly used after significant airtime.
s32 getAppliedHopStickX() const
Factors in vehicle speed to retrieve our hop direction and magnitude.
u16 m_floorCollisionCount
The number of tires colliding with the floor.
void calcDive()
Responds to player input to handle up/down kart tilt mid-air.
void calcOffroad()
Each frame, computes rotation and speed scalars from the floor KCL.
DrivingDirection
The direction the player is currently driving in.
@ WaitingForBackwards
Holding reverse but waiting on a 15 frame delay.
s16 m_timeInRespawn
The number of frames elapsed after position snap from respawn.
s32 m_hopStickX
A ternary for the direction of our hop, 0 if still neutral hopping.
s16 m_backwardsAllowCounter
Tracks the 15f delay before reversing.
f32 calcWallCollisionSpeedFactor(f32 &f1)
Every frame, computes a speed scalar if we are colliding with a wall.
void calcMushroomBoost()
Checks a timer to see if we are still boosting from a mushroom.
f32 m_hopGravity
Always main gravity (-1.3f).
f32 m_hopVelY
Relative velocity due to a hop. Starts at 10 and decreases with gravity.
f32 m_hardSpeedLimit
Absolute speed cap. It's 120, unless you're in a bullet (140).
void setInitialPhysicsValues(const EGG::Vector3f &position, const EGG::Vector3f &angles)
Initializes the kart's position and rotation. Calls tire suspension initializers.
f32 m_rawTurn
Float in range [-1, 1]. Represents stick magnitude + direction.
void setOffroadInvincibility(s16 timer)
Ignores offroad KCL collision for a set amount of time.
f32 m_speedRatioCapped
m_speedRatio but capped at 1.0f.
EGG::Vector3f m_scale
[Unused] Always 1.0f
f32 m_kclWheelSpeedFactor
The slowest speed multiplier of each wheel's floor collision.
EGG::Vector3f m_hopDir
Used for outward drift. Tracks the forward vector of our rotation.
Base class for most kart-related objects.
Pertains to handling reject road.
Pertains to kart-related functionality.
A quaternion, used to represent 3D rotation.
Wrapper around an integral type with an enum corresponding to its bits.
Represents turning information which differs only between inside/outside drift.
Houses parameters that vary between the drift type (inward bike, outward bike, kart).