-
Notifications
You must be signed in to change notification settings - Fork 66
Description
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.