diff options
author | devloglogan <devloglogan@gmail.com> | 2024-05-24 16:18:33 -0500 |
---|---|---|
committer | devloglogan <devloglogan@gmail.com> | 2024-05-29 07:52:54 -0500 |
commit | 6a8f2f00ac41d8977b0085203980f889a9644e23 (patch) | |
tree | e66920853792fae39f617adb49c2a4f4c9339066 /modules/openxr/scene/openxr_composition_layer_quad.cpp | |
parent | b7feebefabc2d48b0d4794cd31fc141f1caecc5c (diff) | |
download | redot-engine-6a8f2f00ac41d8977b0085203980f889a9644e23.tar.gz |
Apply reference frame transform to OpenXRCompositionLayer nodes
Diffstat (limited to 'modules/openxr/scene/openxr_composition_layer_quad.cpp')
-rw-r--r-- | modules/openxr/scene/openxr_composition_layer_quad.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/modules/openxr/scene/openxr_composition_layer_quad.cpp b/modules/openxr/scene/openxr_composition_layer_quad.cpp index 8c5b8ec26b..21919496d6 100644 --- a/modules/openxr/scene/openxr_composition_layer_quad.cpp +++ b/modules/openxr/scene/openxr_composition_layer_quad.cpp @@ -50,6 +50,7 @@ OpenXRCompositionLayerQuad::OpenXRCompositionLayerQuad() { { (float)quad_size.x, (float)quad_size.y }, // size }; openxr_layer_provider = memnew(OpenXRViewportCompositionLayerProvider((XrCompositionLayerBaseHeader *)&composition_layer)); + XRServer::get_singleton()->connect("reference_frame_changed", callable_mp(this, &OpenXRCompositionLayerQuad::update_transform)); } OpenXRCompositionLayerQuad::~OpenXRCompositionLayerQuad() { @@ -72,14 +73,15 @@ Ref<Mesh> OpenXRCompositionLayerQuad::_create_fallback_mesh() { void OpenXRCompositionLayerQuad::_notification(int p_what) { switch (p_what) { case NOTIFICATION_LOCAL_TRANSFORM_CHANGED: { - Transform3D transform = get_transform(); - Quaternion quat(transform.basis.orthonormalized()); - composition_layer.pose.orientation = { (float)quat.x, (float)quat.y, (float)quat.z, (float)quat.w }; - composition_layer.pose.position = { (float)transform.origin.x, (float)transform.origin.y, (float)transform.origin.z }; + update_transform(); } break; } } +void OpenXRCompositionLayerQuad::update_transform() { + composition_layer.pose = get_openxr_pose(); +} + void OpenXRCompositionLayerQuad::set_quad_size(const Size2 &p_size) { quad_size = p_size; composition_layer.size = { (float)quad_size.x, (float)quad_size.y }; |