// Copyright 2019-2020, Collabora, Ltd. // SPDX-License-Identifier: BSL-1.0 /*! * @file * @brief Hand Tracking API interface. * @author Christoph Haag * @ingroup aux_util */ #pragma once #include "xrt/xrt_defines.h" #include "util/u_misc.h" #ifdef __cplusplus extern "C" { #endif /*! * The hand tracking model being used. * * XRT_HAND_TRACKING_MODEL_INTRINSIC for devices that measure hand tracking through sensors, ie gloves and knuckles * XRT_HAND_TRACKING_MODEL_EXTRINSIC for devices that measure hand tracking through external factors like cameras * * @ingroup aux_util */ enum u_hand_tracking_model { XRT_HAND_TRACKING_MODEL_INTRINSIC, XRT_HAND_TRACKING_MODEL_EXTRINSIC, }; struct u_hand_tracking_finger_value { float splay; float joint_curls[5]; int joint_count; }; struct u_hand_tracking_values { struct u_hand_tracking_finger_value little; struct u_hand_tracking_finger_value ring; struct u_hand_tracking_finger_value middle; struct u_hand_tracking_finger_value index; struct u_hand_tracking_finger_value thumb; }; /*! * Values used for the XRT_HAND_TRACKING_MODEL_FINGERL_CURL model. * * @ingroup aux_util */ struct u_hand_tracking_curl_values { float little; float ring; float middle; float index; float thumb; }; /*! * A space relation of a single joint. * * @ingroup aux_util */ struct u_joint_space_relation { enum xrt_hand_joint joint_id; struct xrt_space_relation relation; }; /*! * A set of joints in a single finger. * * @ingroup aux_util */ struct u_finger_joint_set { struct u_joint_space_relation joints[5]; int joint_count; }; /*! * The set of joints in the XR_HAND_JOINT_SET_DEFAULT_EXT. * * @ingroup aux_util */ struct u_hand_joint_default_set { struct u_joint_space_relation palm; struct u_joint_space_relation wrist; struct u_finger_joint_set fingers[XRT_FINGER_COUNT]; }; /*! * Main struct drivers can use to implement hand and finger tracking. * * @ingroup aux_util */ struct u_hand_tracking { // scales dimensions like bone lengths float scale; enum u_hand_tracking_model model; union { struct u_hand_tracking_values finger_values; } model_data; struct u_hand_joint_default_set joints; uint64_t timestamp_ns; }; /*! * @ingroup aux_util */ bool u_hand_joint_is_tip(enum xrt_hand_joint joint); /*! * @ingroup aux_util */ bool u_hand_joint_is_metacarpal(enum xrt_hand_joint joint); /*! * @ingroup aux_util */ bool u_hand_joint_is_proximal(enum xrt_hand_joint joint); /*! * @ingroup aux_util */ bool u_hand_joint_is_intermediate(enum xrt_hand_joint joint); /*! * @ingroup aux_util */ bool u_hand_joint_is_distal(enum xrt_hand_joint joint); /*! * @ingroup aux_util */ bool u_hand_joint_is_thumb(enum xrt_hand_joint joint); /*! * Simple helper function for positioning hands on Valve Index controllers. * * @ingroup aux_util */ void u_hand_joints_offset_valve_index_controller(enum xrt_hand hand, const struct xrt_vec3 *static_offset, struct xrt_pose *offset); #ifdef __cplusplus } #endif