My simple jump unintentionally works as multi jump

Hi, I’m making a 2D game and I need a simple jump code. I’ve learnt how to do it, have done it before in 3D games, but for some reason it’s bugging out in this one and I can’t figure out why.
This is the bit of my jump and movement code:

public bool onGround;

    public void Start()
    {
        runSpeed = 2.5f;
        jumpForce = 13f;
        onGround = true;
        rb = GetComponent<Rigidbody2D>();
    }
    private void Awake()
    {
        rb = GetComponent<Rigidbody2D>();
    }


    void FixedUpdate()
    {
        Horizontal = Input.GetAxis("Horizontal") * runSpeed;

        rb.velocity = new Vector2(Horizontal * runSpeed, rb.velocity.y);

        jump = Input.GetButtonDown("Jump");

        if ((onGround) && (jump) == true)
        {
            jumpVelocity = new Vector2(0f, jumpForce);
            rb.velocity += jumpVelocity;
            onGround = false;
        }
        onGround = true;
    }

If onGround and jump are both true, then the jump action should occur. Else, onGround is set to false and no jumping should occur, even if the player presses the jump key. Yet, I can jump in the air. onGround is perma set to true for some reason. I even tried setting it to false when declaring the bool at the top.

You are setting onGround = true after your if statement so next FixedUpdate it will be true.

If I remove that, it only allows me one jump per entire runtime of the game.

You have to check for the ground to make it true. Once true the player will be allowed to jump, when the player does jump you can make jumping invalidated for a short period of time and/or wait for a button release before allowing another jump; to give the player time to leave the ground.

I thought I was already doing that. If my code isn’t doing that, can you point out where exactly I’m wrong? To my understanding I already implemented the logic you described.

if ((onGround) && (jump) == true) {... //here I check for the ground to see if true

rb.velocity += jumpVelocity; //once ground is true, this executes the jump action```

[quote="adehm, post:4, topic: 850711, username:adehm"]
when the player does jump you can make jumping invalidated for a short period of time and/or wait for a button release before allowing another jump; to give the player time to leave the ground.
[/quote]
```onGround = false; // jumping is invalidated here by setting onGround to false.
The jump action can only execute if both onGround and jump key are true. ```

You arent checking if they are actually on the ground. You are just setting it via code, not checking by collision or layer if a player is on the layer or tag of Ground. As mentioned above, onGround is set in FixedUpdate so it is become true (almost) every single frame instead of only being true when the Player comes in contact with the ground.

I recommend watching this great foundation tutorial and reworking your code. It will give you a great framework to move, jump, add animations and more custom functions to your player’s movement.

I watched that video when I first started. It helped but the jump was still awkward. I think it’s because I already knew one method of implementing movement and jump and then tried to integrate parts of what he explained in the video in my already written script and it didn’t work. But doing it entirely his way worked!
Thanks for reminding me of the video.

However, I ran into another bug (a feature that worked before I reformatted my movement and jump code). Should I open a new thread for that?

You seem to be talking over the main point and answer above which is simply setting a field to “isGround = true” doesn’t mean you’re on the ground. You need to know that’s true by querying the environment, typically by using physics queries to determine that.

You cannot simply do it using logic such as the player not moving in the upward direction because this can easily be fooled such as when gravity slows the player to a standstill in the air while falling.

Whether the jump was “awkward” or not isn’t the purpose of the tutorial. It’s not about telling you how you want the feel of your game to be but more of how you do the basics of determining things like touching the ground, getting the player to move.

If you want better feeling movement, I have another video for you. This one is really great and I use almost all of the concepts shown:

Um, what? I’m not talking over any point or saying anything bad about the answer above or the video. I thanked the user for reminding me of the video. I said doing it exactly like the tutorial worked. What’s with the random hostility?

Sorry if you thought it was hostile and I didn’t say you said anything bad; those are your words not mine.

As I said, you didn’t address the point being made above about you not actually checking if you’re grounded and I go on to explain what that means.

Don’t worry, I don’t need another video. I didn’t say anything about the movement not being smooth after following the previous video you shared. I don’t know what the above user is on about.
I’m grateful for your answer and I expressed that.

The only thing I can think of that might be confusing you guys is that I added extra details on top of just saying “thanks” lol. It was simply to add context about what I tried before and emphasise that following the video exactly as it is works.

Alright, I see. No worries then, just a misunderstanding. I did understand what checking the player is grounded meant after following the video and realised part of what I was doing wrong. So yes, the video was helpful with that!

So you know, I am in charge of 2D physics for Unity so I’m in a good position to help you which is what I was trying to do.

I think so yes. We get such a massive spectrum of skill levels posting here on the forums that’s it’s difficult know who you’re talking to and to what level you should help. Your code indicated a complete misunderstanding of what grounded meant so you have to go with what you see. We don’t always know!

Anyway, good luck with your project.

@Skelbo I still recommend that video because of the early and late input forgiveness mechanics that are used in just about all games. I dont just recommend it, i highly recommend it :slight_smile:

Yeah I’m quite a noob at game programming. There’s so much information to take in, it’s hard to remember it all!

I’ll have a look at it, thanks!