|
@@ -32,6 +32,7 @@
|
|
|
|
|
|
#include "../openxr_api.h"
|
|
|
|
|
|
+#include "core/config/project_settings.h"
|
|
|
#include "core/string/print_string.h"
|
|
|
#include "servers/xr_server.h"
|
|
|
|
|
@@ -59,7 +60,6 @@ HashMap<String, bool *> OpenXRHandTrackingExtension::get_requested_extensions()
|
|
|
|
|
|
request_extensions[XR_EXT_HAND_TRACKING_EXTENSION_NAME] = &hand_tracking_ext;
|
|
|
request_extensions[XR_EXT_HAND_JOINTS_MOTION_RANGE_EXTENSION_NAME] = &hand_motion_range_ext;
|
|
|
- request_extensions[XR_FB_HAND_TRACKING_AIM_EXTENSION_NAME] = &hand_tracking_aim_state_ext;
|
|
|
|
|
|
return request_extensions;
|
|
|
}
|
|
@@ -106,17 +106,11 @@ void OpenXRHandTrackingExtension::on_state_ready() {
|
|
|
}
|
|
|
|
|
|
// Setup our hands and reset data
|
|
|
- for (int i = 0; i < MAX_OPENXR_TRACKED_HANDS; i++) {
|
|
|
+ for (int i = 0; i < OPENXR_MAX_TRACKED_HANDS; i++) {
|
|
|
// we'll do this later
|
|
|
hand_trackers[i].is_initialized = false;
|
|
|
hand_trackers[i].hand_tracker = XR_NULL_HANDLE;
|
|
|
|
|
|
- hand_trackers[i].aimState.aimPose = { { 0.0, 0.0, 0.0, 0.0 }, { 0.0, 0.0, 0.0 } };
|
|
|
- hand_trackers[i].aimState.pinchStrengthIndex = 0.0;
|
|
|
- hand_trackers[i].aimState.pinchStrengthMiddle = 0.0;
|
|
|
- hand_trackers[i].aimState.pinchStrengthRing = 0.0;
|
|
|
- hand_trackers[i].aimState.pinchStrengthLittle = 0.0;
|
|
|
-
|
|
|
hand_trackers[i].locations.isActive = false;
|
|
|
|
|
|
for (int j = 0; j < XR_HAND_JOINT_COUNT_EXT; j++) {
|
|
@@ -141,7 +135,7 @@ void OpenXRHandTrackingExtension::on_process() {
|
|
|
|
|
|
XrResult result;
|
|
|
|
|
|
- for (int i = 0; i < MAX_OPENXR_TRACKED_HANDS; i++) {
|
|
|
+ for (int i = 0; i < OPENXR_MAX_TRACKED_HANDS; i++) {
|
|
|
if (hand_trackers[i].hand_tracker == XR_NULL_HANDLE) {
|
|
|
XrHandTrackerCreateInfoEXT createInfo = {
|
|
|
XR_TYPE_HAND_TRACKER_CREATE_INFO_EXT, // type
|
|
@@ -157,18 +151,6 @@ void OpenXRHandTrackingExtension::on_process() {
|
|
|
hand_trackers[i].is_initialized = false;
|
|
|
} else {
|
|
|
void *next_pointer = nullptr;
|
|
|
- if (hand_tracking_aim_state_ext) {
|
|
|
- hand_trackers[i].aimState.type = XR_TYPE_HAND_TRACKING_AIM_STATE_FB;
|
|
|
- hand_trackers[i].aimState.next = next_pointer;
|
|
|
- hand_trackers[i].aimState.status = 0;
|
|
|
- hand_trackers[i].aimState.aimPose = { { 0.0, 0.0, 0.0, 0.0 }, { 0.0, 0.0, 0.0 } };
|
|
|
- hand_trackers[i].aimState.pinchStrengthIndex = 0.0;
|
|
|
- hand_trackers[i].aimState.pinchStrengthMiddle = 0.0;
|
|
|
- hand_trackers[i].aimState.pinchStrengthRing = 0.0;
|
|
|
- hand_trackers[i].aimState.pinchStrengthLittle = 0.0;
|
|
|
-
|
|
|
- next_pointer = &hand_trackers[i].aimState;
|
|
|
- }
|
|
|
|
|
|
hand_trackers[i].velocities.type = XR_TYPE_HAND_JOINT_VELOCITIES_EXT;
|
|
|
hand_trackers[i].velocities.next = next_pointer;
|
|
@@ -219,20 +201,6 @@ void OpenXRHandTrackingExtension::on_process() {
|
|
|
!hand_trackers[i].locations.isActive || isnan(palm.position.x) || palm.position.x < -1000000.00 || palm.position.x > 1000000.00) {
|
|
|
hand_trackers[i].locations.isActive = false; // workaround, make sure its inactive
|
|
|
}
|
|
|
-
|
|
|
- /* TODO change this to managing the controller from openxr_interface
|
|
|
- if (hand_tracking_aim_state_ext && hand_trackers[i].locations.isActive && check_bit(XR_HAND_TRACKING_AIM_VALID_BIT_FB, hand_trackers[i].aimState.status)) {
|
|
|
- // Controllers are updated based on the aim state's pose and pinches' strength
|
|
|
- if (hand_trackers[i].aim_state_godot_controller == -1) {
|
|
|
- hand_trackers[i].aim_state_godot_controller =
|
|
|
- arvr_api->godot_arvr_add_controller(
|
|
|
- const_cast<char *>(hand_controller_names[i]),
|
|
|
- i + HAND_CONTROLLER_ID_OFFSET,
|
|
|
- true,
|
|
|
- true);
|
|
|
- }
|
|
|
- }
|
|
|
- */
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -246,7 +214,7 @@ void OpenXRHandTrackingExtension::cleanup_hand_tracking() {
|
|
|
XRServer *xr_server = XRServer::get_singleton();
|
|
|
ERR_FAIL_NULL(xr_server);
|
|
|
|
|
|
- for (int i = 0; i < MAX_OPENXR_TRACKED_HANDS; i++) {
|
|
|
+ for (int i = 0; i < OPENXR_MAX_TRACKED_HANDS; i++) {
|
|
|
if (hand_trackers[i].hand_tracker != XR_NULL_HANDLE) {
|
|
|
xrDestroyHandTrackerEXT(hand_trackers[i].hand_tracker);
|
|
|
|
|
@@ -260,25 +228,25 @@ bool OpenXRHandTrackingExtension::get_active() {
|
|
|
return handTrackingSystemProperties.supportsHandTracking;
|
|
|
}
|
|
|
|
|
|
-const OpenXRHandTrackingExtension::HandTracker *OpenXRHandTrackingExtension::get_hand_tracker(uint32_t p_hand) const {
|
|
|
- ERR_FAIL_UNSIGNED_INDEX_V(p_hand, MAX_OPENXR_TRACKED_HANDS, nullptr);
|
|
|
+const OpenXRHandTrackingExtension::HandTracker *OpenXRHandTrackingExtension::get_hand_tracker(HandTrackedHands p_hand) const {
|
|
|
+ ERR_FAIL_UNSIGNED_INDEX_V(p_hand, OPENXR_MAX_TRACKED_HANDS, nullptr);
|
|
|
|
|
|
return &hand_trackers[p_hand];
|
|
|
}
|
|
|
|
|
|
-XrHandJointsMotionRangeEXT OpenXRHandTrackingExtension::get_motion_range(uint32_t p_hand) const {
|
|
|
- ERR_FAIL_UNSIGNED_INDEX_V(p_hand, MAX_OPENXR_TRACKED_HANDS, XR_HAND_JOINTS_MOTION_RANGE_MAX_ENUM_EXT);
|
|
|
+XrHandJointsMotionRangeEXT OpenXRHandTrackingExtension::get_motion_range(HandTrackedHands p_hand) const {
|
|
|
+ ERR_FAIL_UNSIGNED_INDEX_V(p_hand, OPENXR_MAX_TRACKED_HANDS, XR_HAND_JOINTS_MOTION_RANGE_MAX_ENUM_EXT);
|
|
|
|
|
|
return hand_trackers[p_hand].motion_range;
|
|
|
}
|
|
|
|
|
|
-void OpenXRHandTrackingExtension::set_motion_range(uint32_t p_hand, XrHandJointsMotionRangeEXT p_motion_range) {
|
|
|
- ERR_FAIL_UNSIGNED_INDEX(p_hand, MAX_OPENXR_TRACKED_HANDS);
|
|
|
+void OpenXRHandTrackingExtension::set_motion_range(HandTrackedHands p_hand, XrHandJointsMotionRangeEXT p_motion_range) {
|
|
|
+ ERR_FAIL_UNSIGNED_INDEX(p_hand, OPENXR_MAX_TRACKED_HANDS);
|
|
|
hand_trackers[p_hand].motion_range = p_motion_range;
|
|
|
}
|
|
|
|
|
|
-Quaternion OpenXRHandTrackingExtension::get_hand_joint_rotation(uint32_t p_hand, XrHandJointEXT p_joint) const {
|
|
|
- ERR_FAIL_UNSIGNED_INDEX_V(p_hand, MAX_OPENXR_TRACKED_HANDS, Quaternion());
|
|
|
+Quaternion OpenXRHandTrackingExtension::get_hand_joint_rotation(HandTrackedHands p_hand, XrHandJointEXT p_joint) const {
|
|
|
+ ERR_FAIL_UNSIGNED_INDEX_V(p_hand, OPENXR_MAX_TRACKED_HANDS, Quaternion());
|
|
|
ERR_FAIL_UNSIGNED_INDEX_V(p_joint, XR_HAND_JOINT_COUNT_EXT, Quaternion());
|
|
|
|
|
|
if (!hand_trackers[p_hand].is_initialized) {
|
|
@@ -289,8 +257,8 @@ Quaternion OpenXRHandTrackingExtension::get_hand_joint_rotation(uint32_t p_hand,
|
|
|
return Quaternion(location.pose.orientation.x, location.pose.orientation.y, location.pose.orientation.z, location.pose.orientation.w);
|
|
|
}
|
|
|
|
|
|
-Vector3 OpenXRHandTrackingExtension::get_hand_joint_position(uint32_t p_hand, XrHandJointEXT p_joint) const {
|
|
|
- ERR_FAIL_UNSIGNED_INDEX_V(p_hand, MAX_OPENXR_TRACKED_HANDS, Vector3());
|
|
|
+Vector3 OpenXRHandTrackingExtension::get_hand_joint_position(HandTrackedHands p_hand, XrHandJointEXT p_joint) const {
|
|
|
+ ERR_FAIL_UNSIGNED_INDEX_V(p_hand, OPENXR_MAX_TRACKED_HANDS, Vector3());
|
|
|
ERR_FAIL_UNSIGNED_INDEX_V(p_joint, XR_HAND_JOINT_COUNT_EXT, Vector3());
|
|
|
|
|
|
if (!hand_trackers[p_hand].is_initialized) {
|
|
@@ -301,8 +269,8 @@ Vector3 OpenXRHandTrackingExtension::get_hand_joint_position(uint32_t p_hand, Xr
|
|
|
return Vector3(location.pose.position.x, location.pose.position.y, location.pose.position.z);
|
|
|
}
|
|
|
|
|
|
-float OpenXRHandTrackingExtension::get_hand_joint_radius(uint32_t p_hand, XrHandJointEXT p_joint) const {
|
|
|
- ERR_FAIL_UNSIGNED_INDEX_V(p_hand, MAX_OPENXR_TRACKED_HANDS, 0.0);
|
|
|
+float OpenXRHandTrackingExtension::get_hand_joint_radius(HandTrackedHands p_hand, XrHandJointEXT p_joint) const {
|
|
|
+ ERR_FAIL_UNSIGNED_INDEX_V(p_hand, OPENXR_MAX_TRACKED_HANDS, 0.0);
|
|
|
ERR_FAIL_UNSIGNED_INDEX_V(p_joint, XR_HAND_JOINT_COUNT_EXT, 0.0);
|
|
|
|
|
|
if (!hand_trackers[p_hand].is_initialized) {
|
|
@@ -312,8 +280,8 @@ float OpenXRHandTrackingExtension::get_hand_joint_radius(uint32_t p_hand, XrHand
|
|
|
return hand_trackers[p_hand].joint_locations[p_joint].radius;
|
|
|
}
|
|
|
|
|
|
-Vector3 OpenXRHandTrackingExtension::get_hand_joint_linear_velocity(uint32_t p_hand, XrHandJointEXT p_joint) const {
|
|
|
- ERR_FAIL_UNSIGNED_INDEX_V(p_hand, MAX_OPENXR_TRACKED_HANDS, Vector3());
|
|
|
+Vector3 OpenXRHandTrackingExtension::get_hand_joint_linear_velocity(HandTrackedHands p_hand, XrHandJointEXT p_joint) const {
|
|
|
+ ERR_FAIL_UNSIGNED_INDEX_V(p_hand, OPENXR_MAX_TRACKED_HANDS, Vector3());
|
|
|
ERR_FAIL_UNSIGNED_INDEX_V(p_joint, XR_HAND_JOINT_COUNT_EXT, Vector3());
|
|
|
|
|
|
if (!hand_trackers[p_hand].is_initialized) {
|
|
@@ -324,8 +292,8 @@ Vector3 OpenXRHandTrackingExtension::get_hand_joint_linear_velocity(uint32_t p_h
|
|
|
return Vector3(velocity.linearVelocity.x, velocity.linearVelocity.y, velocity.linearVelocity.z);
|
|
|
}
|
|
|
|
|
|
-Vector3 OpenXRHandTrackingExtension::get_hand_joint_angular_velocity(uint32_t p_hand, XrHandJointEXT p_joint) const {
|
|
|
- ERR_FAIL_UNSIGNED_INDEX_V(p_hand, MAX_OPENXR_TRACKED_HANDS, Vector3());
|
|
|
+Vector3 OpenXRHandTrackingExtension::get_hand_joint_angular_velocity(HandTrackedHands p_hand, XrHandJointEXT p_joint) const {
|
|
|
+ ERR_FAIL_UNSIGNED_INDEX_V(p_hand, OPENXR_MAX_TRACKED_HANDS, Vector3());
|
|
|
ERR_FAIL_UNSIGNED_INDEX_V(p_joint, XR_HAND_JOINT_COUNT_EXT, Vector3());
|
|
|
|
|
|
if (!hand_trackers[p_hand].is_initialized) {
|