Animator.SetBool is working the first time, but not the second time?

Hey guys, I’m making a project for a Hololens 2. I’ve got a simple character with two states in the animator: Idle and walking. The Idle state can transition to walking if the isWalking parameter is set to true, and the walking state can transition to idle if the isWalking parameter is set to false.

When I click the checkbox manually in the Animator window when my project is running, it works.

The first time when I set “isWalking” via code, it also works. But then when I set isWalking to false, nothing happens, worse, it seems like the method is throwing an invisible exception because it doesn’t even hit the “Done setting walking” flag! WTF??

I’m on Unity 2019.4.10 LTS

private void SetCharacterWalking(bool walking)
    {
        Debug.Log($"Character walk state set: {walking}");
        CharacterAnimator.SetBool("isWalking", walking);
        Debug.Log("Done setting walking flag");
    }

OK, fixed it, it was a thread issue. I was using a System.Timers.Timer to trigger the method. Now I’m just using the timer to set a private bool and do the work in the update method.

Screw that, I’m just ditching System.Timers.Timer altogether, I remember having a lot of issues with it in Unity in the past. Switched to coroutines to make a simple timer.