Skip to content

Sequential calls to ref.setInputState results in only the last one being updating in the animation. #265

@CoopCodes

Description

@CoopCodes

Description

When using Rive with React Native, setting multiple input states sequentially does not work as expected. Only the last input change is reflected in the animation, ignoring previous input changes.

Provide a Repro

Here's a minimal code snippet that reproduces the issue:

MonsterRef.current?.setInputState(stateMachineName, "Many Teeth Mouth", true);
MonsterRef.current?.setInputState(stateMachineName, "Many Eyes", true);

In this example, only the "Many Eyes" input change is reflected in the animation, while the "Many Teeth Mouth" input is ignored.

A workaround using setTimeout and Promises works:

new Promise((resolve) => {
  setTimeout(() => {
    MonsterRef.current?.setInputState(stateMachineName, "Many Teeth Mouth", true)
    resolve(null);
  }, 50)
}).then(() => {
  setTimeout(() => {
    MonsterRef.current?.setInputState(stateMachineName, "Many Eyes", true);
  }, 50)
});

Expected behavior

When setting multiple input states sequentially, all input changes should be reflected in the animation, not just the last one.

Screenshots

N/A

Device & Versions (please complete the following information)

  • Device: Google Pixel 7 API 34, ran on Android Studio Device Manager (emulator) with Windows 11.
  • OS: Windows 11 Version 23H2
  • NPM Version: 10.8.1

Additional context

This is functionality for part of my app where you can customize your character, using several different body parts. The state machine has an input for each bodypart, the input is of type "trigger".
I have been able to work around this will a mess of Promises and setTimeouts, ensuring none run at the same time. But as my codebase grows I will not be able to keep this up.

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions