Skip to content

Conversation

@BastiaanOlij
Copy link
Member

The function WaitGetPoses returns two sets of tracking data. Tracking data for the current frame, and predictive tracking data for the next frame.

We call, as we should, WaitGetPoses as close to when we render as possible, however we do not update the positions of our node until we process the next frame.

This PR ensures that our head position for rendering uses the most up to date tracking data as we currently do, but we now use the predictive tracking data for the next frame when positioning nodes.

Now Godot 3 still processes this data within _process so we do not have the nodes in the correct position until after that nodes _process has run, but this can be dealt with. This is something that has been improved in Godot 4.

But with this fix it should ensure that controller positions no longer seem to be a frame behind and more importantly, that nodes childed to the ARVRCamera will appear in the correct position.

@BastiaanOlij BastiaanOlij added this to the 1.2.0 milestone Jan 26, 2022
@BastiaanOlij BastiaanOlij self-assigned this Jan 26, 2022
@beniwtv
Copy link
Collaborator

beniwtv commented Jan 28, 2022

Very cool! Gonna have to give this a spin soon :)

@fire
Copy link
Contributor

fire commented Oct 6, 2025

@vilhalmer Is this still relevant?

@vilhalmer
Copy link
Collaborator

I have no idea, I'm hoping to go through the remaining PRs after I get my last set posted which should be very soon now that #169 is in.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants