We have encountered an issue with the following function:
FMOD::Channel::getPosition(unsigned int *position, FMOD_TIMEUNIT postype)
Context:
We are currently developing a rhythm game that is already in production. We utilize FMOD for reading WAV files and synchronizing gameplay to the music. In our game, the movement of actors is relative to the music’s timing.
Symptoms:
Every 4-6 frames, the getPosition function returns the same value as the previous one. As a result, we observe a noticeable “lag” in the movement of all actors every 4-6 frames.
Here’s the code snippet used to obtain the timing:
Is there a way to potentially smooth out the getPosition function?
Note: We are aware that we “could” use UE4 deltaTime. However, for some reason, on certain hardware, towards the end of the song, we noticed that getPosition can be up to 2 seconds behind UE4 time (which is not feasible for a rhythm game).
I’ve been able to reproduce the exact behavior you’re describing, but unfortunately cannot offer a workaround currently. Channel::getPosition technically grabs a shadow position, which is updated asynchronously by the system, which would explain the behaviour you’re seeing. However, the typical recommendation of using Channel::getDSPClock to access the channels’ underlying DSP clock in memory, which would normally provide sample accurate timing, also doesn’t resolve the issue.
I’ll consult with the development team on this, and should get back to you on it soon.
The development team has confirmed that this isn’t expected behaviour, and they’ll be looking into it. Unfortunately, I don’t have a workaround for you besides calculating the average position of the channel in your own code.
Just to follow up on this and clarify - the large interval between FMOD’s channel position updating compared to UE’s delta time is to be expected, as the channel position updating is not explicitly based on elapsed time, but on the latest update to the DSP buffer. Typically this is both slower than and not evenly divisible by UE’s delta time, leading to the “lag” you’re experiencing. Lowering the value of your “DSPBuffer Length” in Project Settings → Plugins → FMOD Studio → Init Settings may help, but there will likely be some mismatch regardless.
As mentioned previously, averaging FMOD’s channel position delta yourself would be a workaround, but this mismatch is expected behavior, the more pressing concern is the drift in timing between UE4 and FMOD. If this is still an issue, would you mind elaborating on the gap of two seconds that you’ve observed, the structure of the audio/event in question, as well as what hardware it occurs on?