Draft: Seamless Integration of XR Tracking in Godot Engine
Metadata
- Status: Proposed
- Deciders: V-Sekai Project Maintainers
- Tags: XR, Hand Tracking, Full Body Tracking, OpenXR, Godot Engine, Animation Retargeting
The Backdrop
The document outlines the need for supporting hand and full body tracking in extended reality (XR) applications. As virtual and augmented reality technologies improve, developers seek methods to integrate external skeleton data, such as OpenXR hand tracking or “full body tracking” skeletons, with existing imported and skinned meshes within the Godot Engine.
The Challenge
The current implementation of OpenXR provides a bone structure model for hand tracking data, which is incorporated into the Godot Engine through an OpenXRHand
helper node. This node transforms global position and orientation data into local space. However, this approach has compatibility issues due to the requirement that mesh structures strictly adhere to the OpenXR standard. Additionally, there’s a growing need to support solutions for vendor APIs offering “full body tracking” skeletons.
The Strategy
To address these limitations, we propose the introduction of an OpenXRSkeleton3D
node. This new node will:
- Conform to the OpenXR standard for consistency.
- Include hardcoded rest poses based on open hands recorded using OpenXR to simplify development.
- Apply tracked OpenXR data dynamically to generate pose animations.
This strategy enables advanced retargeting scenarios and improves the integration of partial tracking data to hand meshes, humanoid skeletons, and blending of tracked poses with static ones for specific interactions like object manipulation.
Unique Use Cases Catered To
Augmented Reality (AR)
In AR, deforming the mesh to match the player’s actual hands and fingers can significantly enhance realism.
Virtual Reality (VR)
In VR, this strategy enables the representation of fixed-size avatar hands that do not vary with the player’s real hand size, similar to games like “Half-Life Alyx.”
Compatibility with Other Systems
The proposed solution will improve interoperability with other systems and standards, such as:
- Apple’s Vision Pro: By implementing an
AppleSkeleton3D
node to accommodate format and skeleton definitions differences. - WebXR: Potentially aligning with the OpenXR system.
- Godot Engine: Including additional metacarpal bones in the engine’s humanoid skeleton for accurate retargeting.
Non-XR Use Cases Showcasing Broader Utility
The system could also be beneficial for non-XR applications such as:
- Adjusting leg movement to avoid ground collision.
- Supporting procedural foot-planting techniques for realistic animation.
- Tracking arms for dynamic motion capture.
- Allowing inverse kinematics setups similar to classic shooters like Doom (2016).
- Providing active ragdolls for lifelike physics responses, exemplified in Godot Engine Active Ragdolls.
Core Components
- XR-Specific Node: This component extracts and refines hand-tracking data into a specialized
Skeleton3D
node. - Animation BlendTree Node: This node handles the complex task of retargeting data across different skeletons, enabling a mix-and-match approach to animation and physical interactions.
Application Scenarios
A typical use case may involve two hand skeletons from different tracking sources being retargeted onto a third skeleton dedicated to visual representation within the Godot Engine environment or for physics-based interactions.
Further Reading
- V-Sekai · GitHub - Official GitHub account for the V-Sekai development community focusing on social VR functionality for the Godot Engine.
- V-Sekai/v-sekai-game - GitHub page for the V-Sekai open-source project bringing social VR/VRSNS/metaverse components to the Godot Engine.
AI assistant Aria assisted with this article.