Skip to main content

Indie game storeFree gamesFun gamesHorror games
Game developmentAssetsComics
SalesBundles
Jobs
TagsGame Engines

Rick van Leeuwen

2
Posts
4
Followers
6
Following
A member registered Feb 15, 2023 · View creator page →

Creator of

Recent community posts

I tried this and it didn't solve it. It only reduced the likelihood. I now understand why  the superjump happens though:

This dev log doesn't contain the full gravity multiplier check needed to handle jumping properly. Copying just what you see here will make your gravityMultiplier variable set itself to your jump cutoff. This is because it's missing a ground check. There's a lot more stuff missing for this gravityMultiplier. Go check out the calculateGravity function in the scripts you can download here.

(1 edit)

Small note for those that opt to rewrite this code manually instead of downloading the files:

The movement script needs to copy the rigidbody velocity or it will set the Y velocity to 0. Just add:
velocity = body.velocity;

Place it under the onGround check in FixedUpdate. As far as I know this makes it all work as intended. Lastly:

The variables you can input in the game itself aren't accurate reflections of their Unity Editor values. Check the downloaded scripts to see what the in game options are for these values.


Update: I believe I have found and solved the problem giving the player a super jump. If you're rewriting the code yourself here's what's missing:

When you (are on) land, your gravity multiplier is supposed to be 1. There's an if statement in FixedUpdate asking if we're going up (body.velocity.Y > 0.01f). This if statement is incomplete. In fact, it's part of a larger check. Long story short, your gravity multiplier is being set to your jump cutoff variable which causes the following jump to overcompensate. I suggest looking in the scripts added to this page. Inside the jump script you'll find a calculateGravity function. All the checks you need are in there.