2022-04-10 13:28:33 +00:00
|
|
|
// Copyright 2019-2022, Collabora, Ltd.
|
2019-03-18 05:52:32 +00:00
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief So much space!
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @ingroup oxr_main
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "math/m_api.h"
|
2020-07-23 11:12:29 +00:00
|
|
|
#include "math/m_space.h"
|
2019-03-18 05:52:32 +00:00
|
|
|
#include "util/u_debug.h"
|
2019-03-21 20:19:52 +00:00
|
|
|
#include "util/u_misc.h"
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
#include "oxr_objects.h"
|
|
|
|
#include "oxr_logger.h"
|
2019-04-05 19:18:03 +00:00
|
|
|
#include "oxr_handle.h"
|
2022-05-27 18:01:37 +00:00
|
|
|
#include "oxr_input_transform.h"
|
2022-03-14 23:04:28 +00:00
|
|
|
#include "oxr_chain.h"
|
2022-04-10 16:41:49 +00:00
|
|
|
#include "oxr_pretty_print.h"
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
|
2021-04-26 20:17:29 +00:00
|
|
|
const struct xrt_pose origin = XRT_POSE_IDENTITY;
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
static XrResult
|
|
|
|
check_reference_space_type(struct oxr_logger *log, XrReferenceSpaceType type)
|
|
|
|
{
|
|
|
|
switch (type) {
|
|
|
|
case XR_REFERENCE_SPACE_TYPE_VIEW: return XR_SUCCESS;
|
|
|
|
case XR_REFERENCE_SPACE_TYPE_LOCAL: return XR_SUCCESS;
|
2021-01-22 13:51:08 +00:00
|
|
|
case XR_REFERENCE_SPACE_TYPE_STAGE:
|
|
|
|
// For now stage space is always supported.
|
|
|
|
if (true) {
|
|
|
|
return XR_SUCCESS;
|
|
|
|
}
|
2019-03-18 05:52:32 +00:00
|
|
|
return oxr_error(log, XR_ERROR_REFERENCE_SPACE_UNSUPPORTED,
|
2021-01-22 13:51:08 +00:00
|
|
|
"(createInfo->referenceSpaceType == XR_REFERENCE_SPACE_TYPE_STAGE)"
|
|
|
|
" Stage space is unsupported on this device.");
|
2019-03-18 05:52:32 +00:00
|
|
|
default:
|
|
|
|
return oxr_error(log, XR_ERROR_REFERENCE_SPACE_UNSUPPORTED,
|
2021-01-14 14:13:48 +00:00
|
|
|
"(createInfo->referenceSpaceType == 0x%08x)", type);
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-05 19:18:03 +00:00
|
|
|
static XrResult
|
|
|
|
oxr_space_destroy(struct oxr_logger *log, struct oxr_handle_base *hb)
|
|
|
|
{
|
|
|
|
struct oxr_space *spc = (struct oxr_space *)hb;
|
|
|
|
free(spc);
|
|
|
|
return XR_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2019-04-05 22:28:36 +00:00
|
|
|
XrResult
|
|
|
|
oxr_space_action_create(struct oxr_logger *log,
|
2019-07-13 16:17:57 +00:00
|
|
|
struct oxr_session *sess,
|
2022-04-12 19:36:53 +00:00
|
|
|
uint32_t key,
|
2019-04-05 22:28:36 +00:00
|
|
|
const XrActionSpaceCreateInfo *createInfo,
|
|
|
|
struct oxr_space **out_space)
|
|
|
|
{
|
2019-05-07 12:47:18 +00:00
|
|
|
struct oxr_instance *inst = sess->sys->inst;
|
2020-10-23 12:39:59 +00:00
|
|
|
struct oxr_subaction_paths subaction_paths = {0};
|
2019-05-07 12:47:18 +00:00
|
|
|
|
2019-04-05 22:28:36 +00:00
|
|
|
struct oxr_space *spc = NULL;
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_ALLOCATE_HANDLE_OR_RETURN(log, spc, OXR_XR_DEBUG_SPACE, oxr_space_destroy, &sess->handle);
|
2019-04-05 22:28:36 +00:00
|
|
|
|
2020-10-23 12:39:59 +00:00
|
|
|
oxr_classify_sub_action_paths(log, inst, 1, &createInfo->subactionPath, &subaction_paths);
|
2019-05-07 12:47:18 +00:00
|
|
|
|
2019-07-13 16:17:57 +00:00
|
|
|
spc->sess = sess;
|
2022-03-23 18:20:15 +00:00
|
|
|
spc->space_type = OXR_SPACE_TYPE_ACTION;
|
2020-10-23 12:39:59 +00:00
|
|
|
spc->subaction_paths = subaction_paths;
|
2019-07-13 16:17:57 +00:00
|
|
|
spc->act_key = key;
|
2019-04-05 22:28:36 +00:00
|
|
|
memcpy(&spc->pose, &createInfo->poseInActionSpace, sizeof(spc->pose));
|
|
|
|
|
|
|
|
*out_space = spc;
|
|
|
|
|
|
|
|
return XR_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
XrResult
|
|
|
|
oxr_space_reference_create(struct oxr_logger *log,
|
|
|
|
struct oxr_session *sess,
|
|
|
|
const XrReferenceSpaceCreateInfo *createInfo,
|
|
|
|
struct oxr_space **out_space)
|
|
|
|
{
|
|
|
|
XrResult ret;
|
|
|
|
|
|
|
|
ret = check_reference_space_type(log, createInfo->referenceSpaceType);
|
|
|
|
if (ret != XR_SUCCESS) {
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2021-01-14 14:13:48 +00:00
|
|
|
if (!math_pose_validate((struct xrt_pose *)&createInfo->poseInReferenceSpace)) {
|
|
|
|
return oxr_error(log, XR_ERROR_POSE_INVALID, "(createInfo->poseInReferenceSpace)");
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
|
2019-04-05 19:18:03 +00:00
|
|
|
struct oxr_space *spc = NULL;
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_ALLOCATE_HANDLE_OR_RETURN(log, spc, OXR_XR_DEBUG_SPACE, oxr_space_destroy, &sess->handle);
|
2019-03-18 05:52:32 +00:00
|
|
|
spc->sess = sess;
|
2022-03-23 18:20:15 +00:00
|
|
|
spc->space_type = xr_ref_space_to_oxr(createInfo->referenceSpaceType);
|
2021-01-14 14:13:48 +00:00
|
|
|
memcpy(&spc->pose, &createInfo->poseInReferenceSpace, sizeof(spc->pose));
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
*out_space = spc;
|
|
|
|
|
|
|
|
return XR_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2022-03-01 01:55:43 +00:00
|
|
|
static void
|
|
|
|
print_pose(struct oxr_session *sess, const char *prefix, struct xrt_pose *pose);
|
|
|
|
|
2020-07-19 21:44:24 +00:00
|
|
|
static bool
|
2022-03-01 01:55:43 +00:00
|
|
|
set_up_local_space(struct oxr_logger *log, struct oxr_session *sess, XrTime time)
|
2020-07-19 21:44:24 +00:00
|
|
|
{
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_device *head_xdev = GET_XDEV_BY_ROLE(sess->sys, head);
|
|
|
|
struct xrt_space_relation head_relation;
|
|
|
|
oxr_xdev_get_space_relation(log, sess->sys->inst, head_xdev, XRT_INPUT_GENERIC_HEAD_POSE, time, &head_relation);
|
|
|
|
|
|
|
|
if ((head_relation.relation_flags & XRT_SPACE_RELATION_ORIENTATION_TRACKED_BIT) == 0) {
|
2020-07-19 21:44:24 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2022-03-01 01:55:43 +00:00
|
|
|
if (!is_local_space_set_up(sess)) {
|
|
|
|
sess->local_space_pure_relation = head_relation;
|
2020-07-19 21:44:24 +00:00
|
|
|
|
|
|
|
// take only head rotation around y axis
|
|
|
|
// https://stackoverflow.com/a/5783030
|
2022-03-01 01:55:43 +00:00
|
|
|
sess->local_space_pure_relation.pose.orientation.x = 0;
|
|
|
|
sess->local_space_pure_relation.pose.orientation.z = 0;
|
|
|
|
math_quat_normalize(&sess->local_space_pure_relation.pose.orientation);
|
|
|
|
|
|
|
|
print_pose(sess, "local space updated", &head_relation.pose);
|
2020-07-19 21:44:24 +00:00
|
|
|
|
2020-09-07 23:23:23 +00:00
|
|
|
//! @todo: Handle relation velocities if necessary
|
2020-07-19 21:44:24 +00:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2022-07-13 17:53:17 +00:00
|
|
|
XRT_CHECK_RESULT bool
|
2022-03-01 01:55:43 +00:00
|
|
|
is_local_space_set_up(struct oxr_session *sess)
|
2020-07-19 21:44:24 +00:00
|
|
|
{
|
2022-03-01 01:55:43 +00:00
|
|
|
return (sess->local_space_pure_relation.relation_flags & XRT_SPACE_RELATION_ORIENTATION_VALID_BIT) != 0;
|
2020-07-19 21:44:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-02-13 23:17:06 +00:00
|
|
|
/*!
|
2022-03-01 01:55:43 +00:00
|
|
|
* Returns the pure relation in global space of an oxr_space, meaning the tracking_origin offsets are already applied.
|
|
|
|
*
|
|
|
|
* @todo: Until a proper reference space system is implemented, the xdev assigned to the head role should be used as @p
|
|
|
|
* ref_xdev for consistency.
|
2022-02-13 23:17:06 +00:00
|
|
|
*/
|
2022-03-11 00:19:37 +00:00
|
|
|
XRT_CHECK_RESULT static bool
|
2022-03-01 01:55:43 +00:00
|
|
|
oxr_space_ref_get_pure_relation(struct oxr_logger *log,
|
|
|
|
struct oxr_session *sess,
|
2022-03-23 18:20:15 +00:00
|
|
|
enum oxr_space_type space_type,
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_device *ref_xdev,
|
|
|
|
XrTime time,
|
|
|
|
struct xrt_space_relation *out_relation)
|
2022-02-13 23:17:06 +00:00
|
|
|
{
|
2022-03-23 18:20:15 +00:00
|
|
|
switch (space_type) {
|
|
|
|
case OXR_SPACE_TYPE_REFERENCE_LOCAL: {
|
2022-03-01 01:55:43 +00:00
|
|
|
if (!is_local_space_set_up(sess)) {
|
|
|
|
if (!set_up_local_space(log, sess, time)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2022-02-13 23:17:06 +00:00
|
|
|
|
2022-03-01 01:55:43 +00:00
|
|
|
*out_relation = sess->local_space_pure_relation;
|
|
|
|
return true;
|
2022-02-13 23:17:06 +00:00
|
|
|
}
|
2022-03-23 18:20:15 +00:00
|
|
|
case OXR_SPACE_TYPE_REFERENCE_STAGE: {
|
2022-03-01 01:55:43 +00:00
|
|
|
//! @todo: stage space origin assumed to be the same as HMD xdev space origin for now.
|
2022-02-13 23:17:06 +00:00
|
|
|
m_space_relation_ident(out_relation);
|
2022-03-01 01:55:43 +00:00
|
|
|
return true;
|
|
|
|
}
|
2022-03-23 18:20:15 +00:00
|
|
|
case OXR_SPACE_TYPE_REFERENCE_VIEW: {
|
2022-03-01 01:55:43 +00:00
|
|
|
oxr_xdev_get_space_relation(log, sess->sys->inst, ref_xdev, XRT_INPUT_GENERIC_HEAD_POSE, time,
|
|
|
|
out_relation);
|
|
|
|
return true;
|
2022-02-13 23:17:06 +00:00
|
|
|
}
|
|
|
|
|
2022-03-23 18:20:15 +00:00
|
|
|
case OXR_SPACE_TYPE_REFERENCE_UNBOUNDED_MSFT:
|
|
|
|
case OXR_SPACE_TYPE_REFERENCE_COMBINED_EYE_VARJO:
|
2022-03-01 01:55:43 +00:00
|
|
|
// not implemented
|
2022-03-23 18:20:15 +00:00
|
|
|
return oxr_error(log, false, "Reference Space type %d not implemented!", space_type);
|
|
|
|
case OXR_SPACE_TYPE_ACTION: return oxr_error(log, false, "Space is not a reference space!");
|
2022-03-01 01:55:43 +00:00
|
|
|
}
|
|
|
|
return true;
|
2022-02-13 23:17:06 +00:00
|
|
|
}
|
|
|
|
|
2022-07-13 17:53:17 +00:00
|
|
|
XRT_CHECK_RESULT bool
|
2022-03-01 01:55:43 +00:00
|
|
|
oxr_space_pure_relation_in_space(struct oxr_logger *log,
|
|
|
|
XrTime time,
|
|
|
|
struct xrt_space_relation *relation,
|
|
|
|
struct oxr_space *spc,
|
|
|
|
bool apply_space_pose,
|
|
|
|
struct xrt_space_relation *out_relation)
|
2022-02-13 23:17:06 +00:00
|
|
|
{
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_space_relation pure_space_relation;
|
|
|
|
struct xrt_device *xdev;
|
2022-03-11 00:19:37 +00:00
|
|
|
if (!oxr_space_get_pure_relation(log, spc, time, &pure_space_relation, &xdev)) {
|
|
|
|
return false;
|
|
|
|
}
|
2022-02-13 23:17:06 +00:00
|
|
|
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_relation_chain xrc = {0};
|
|
|
|
|
|
|
|
m_relation_chain_push_relation(&xrc, relation);
|
|
|
|
m_relation_chain_push_inverted_relation(&xrc, &pure_space_relation);
|
|
|
|
|
|
|
|
if (apply_space_pose) {
|
|
|
|
m_relation_chain_push_inverted_pose_if_not_identity(&xrc, &spc->pose);
|
2022-02-13 23:17:06 +00:00
|
|
|
}
|
2022-03-01 01:55:43 +00:00
|
|
|
|
|
|
|
m_relation_chain_resolve(&xrc, out_relation);
|
|
|
|
return true;
|
2022-02-13 23:17:06 +00:00
|
|
|
}
|
|
|
|
|
2022-07-13 17:53:17 +00:00
|
|
|
XRT_CHECK_RESULT bool
|
2022-03-01 01:55:43 +00:00
|
|
|
oxr_space_pure_pose_in_space(struct oxr_logger *log,
|
|
|
|
XrTime time,
|
|
|
|
struct xrt_pose *pose,
|
|
|
|
struct oxr_space *spc,
|
|
|
|
bool apply_space_pose,
|
|
|
|
struct xrt_space_relation *out_relation)
|
2022-02-13 23:17:06 +00:00
|
|
|
{
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_space_relation rel;
|
|
|
|
m_space_relation_from_pose(pose, &rel);
|
|
|
|
return oxr_space_pure_relation_in_space(log, time, &rel, spc, apply_space_pose, out_relation);
|
2022-02-13 23:17:06 +00:00
|
|
|
}
|
|
|
|
|
2022-07-13 17:53:17 +00:00
|
|
|
XRT_CHECK_RESULT bool
|
2022-03-01 01:55:43 +00:00
|
|
|
oxr_space_pure_relation_from_space(struct oxr_logger *log,
|
|
|
|
XrTime time,
|
|
|
|
struct xrt_space_relation *relation,
|
|
|
|
struct oxr_space *spc,
|
|
|
|
struct xrt_space_relation *out_relation)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_space_relation pure_space_relation;
|
|
|
|
struct xrt_device *xdev;
|
2022-03-03 00:42:02 +00:00
|
|
|
if (!oxr_space_get_pure_relation(log, spc, time, &pure_space_relation, &xdev)) {
|
|
|
|
return false;
|
|
|
|
}
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_relation_chain xrc = {0};
|
|
|
|
m_relation_chain_push_relation(&xrc, relation);
|
2022-03-29 23:40:38 +00:00
|
|
|
m_relation_chain_push_pose_if_not_identity(&xrc, &spc->pose);
|
|
|
|
m_relation_chain_push_relation(&xrc, &pure_space_relation);
|
2022-03-01 01:55:43 +00:00
|
|
|
m_relation_chain_resolve(&xrc, out_relation);
|
|
|
|
return true;
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
|
2022-07-13 17:53:17 +00:00
|
|
|
XRT_CHECK_RESULT bool
|
2022-03-01 01:55:43 +00:00
|
|
|
oxr_space_pure_pose_from_space(struct oxr_logger *log,
|
|
|
|
XrTime time,
|
|
|
|
struct xrt_pose *pose,
|
|
|
|
struct oxr_space *spc,
|
|
|
|
struct xrt_space_relation *out_relation)
|
2020-07-23 11:12:29 +00:00
|
|
|
{
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_space_relation rel;
|
|
|
|
m_space_relation_from_pose(pose, &rel);
|
|
|
|
return oxr_space_pure_relation_from_space(log, time, &rel, spc, out_relation);
|
2020-07-23 11:12:29 +00:00
|
|
|
}
|
|
|
|
|
2022-07-13 17:53:17 +00:00
|
|
|
XRT_CHECK_RESULT bool
|
2022-03-01 01:55:43 +00:00
|
|
|
oxr_space_get_pure_relation(struct oxr_logger *log,
|
|
|
|
struct oxr_space *spc,
|
|
|
|
XrTime time,
|
|
|
|
struct xrt_space_relation *out_relation,
|
|
|
|
struct xrt_device **out_xdev)
|
2019-05-07 12:47:18 +00:00
|
|
|
{
|
2022-03-23 18:20:15 +00:00
|
|
|
if (oxr_space_type_is_reference(spc->space_type)) {
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_device *head_xdev = GET_XDEV_BY_ROLE(spc->sess->sys, head);
|
|
|
|
*out_xdev = head_xdev;
|
2022-03-23 18:20:15 +00:00
|
|
|
return oxr_space_ref_get_pure_relation(log, spc->sess, spc->space_type, head_xdev, time, out_relation);
|
2022-04-12 21:20:11 +00:00
|
|
|
}
|
|
|
|
if (spc->space_type == OXR_SPACE_TYPE_ACTION) {
|
2022-03-23 18:20:15 +00:00
|
|
|
struct oxr_action_input *input = NULL;
|
2022-04-10 13:28:33 +00:00
|
|
|
oxr_action_get_pose_input(spc->sess, spc->act_key, &spc->subaction_paths, &input);
|
2022-03-23 18:20:15 +00:00
|
|
|
|
|
|
|
// If the input isn't active.
|
|
|
|
if (input == NULL) {
|
|
|
|
out_relation->relation_flags = XRT_SPACE_RELATION_BITMASK_NONE;
|
|
|
|
return false;
|
|
|
|
}
|
2019-05-07 12:47:18 +00:00
|
|
|
|
2022-03-23 18:20:15 +00:00
|
|
|
*out_xdev = input->xdev;
|
|
|
|
oxr_xdev_get_space_relation(log, spc->sess->sys->inst, input->xdev, input->input->name, time,
|
|
|
|
out_relation);
|
2019-05-07 12:47:18 +00:00
|
|
|
|
2022-03-23 18:20:15 +00:00
|
|
|
return true;
|
2019-05-07 12:47:18 +00:00
|
|
|
}
|
|
|
|
|
2022-03-23 18:20:15 +00:00
|
|
|
return oxr_error(log, false, "Unknown space type");
|
2022-03-01 01:55:43 +00:00
|
|
|
}
|
2020-07-19 21:44:24 +00:00
|
|
|
|
2022-07-13 17:53:17 +00:00
|
|
|
XRT_CHECK_RESULT bool
|
2022-03-01 01:55:43 +00:00
|
|
|
global_to_local_space(struct oxr_logger *log, struct oxr_session *sess, XrTime time, struct xrt_space_relation *rel)
|
|
|
|
{
|
|
|
|
if (!is_local_space_set_up(sess)) {
|
|
|
|
if (!set_up_local_space(log, sess, time)) {
|
|
|
|
return false;
|
|
|
|
}
|
2019-05-07 12:47:18 +00:00
|
|
|
}
|
|
|
|
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_relation_chain xrc = {0};
|
|
|
|
m_relation_chain_push_relation(&xrc, rel);
|
|
|
|
m_relation_chain_push_inverted_pose_if_not_identity(&xrc, &sess->local_space_pure_relation.pose);
|
|
|
|
m_relation_chain_resolve(&xrc, rel);
|
|
|
|
|
|
|
|
return true;
|
2019-05-07 12:47:18 +00:00
|
|
|
}
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
/*!
|
|
|
|
* This returns only the relation between two directly-associated spaces without
|
2022-02-13 23:17:06 +00:00
|
|
|
* the app given offset pose for baseSpc applied.
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
2022-03-11 00:19:37 +00:00
|
|
|
XRT_CHECK_RESULT static bool
|
2019-03-18 05:52:32 +00:00
|
|
|
get_pure_space_relation(struct oxr_logger *log,
|
|
|
|
struct oxr_space *spc,
|
|
|
|
struct oxr_space *baseSpc,
|
|
|
|
XrTime time,
|
|
|
|
struct xrt_space_relation *out_relation)
|
|
|
|
{
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_space_relation space_pure_relation;
|
|
|
|
struct xrt_device *space_xdev;
|
2022-03-11 00:19:37 +00:00
|
|
|
if (!oxr_space_get_pure_relation(log, spc, time, &space_pure_relation, &space_xdev)) {
|
|
|
|
return false;
|
|
|
|
}
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2022-03-01 01:55:43 +00:00
|
|
|
struct xrt_space_relation base_space_pure_relation;
|
|
|
|
struct xrt_device *base_space_xdev;
|
2022-03-11 00:19:37 +00:00
|
|
|
if (!oxr_space_get_pure_relation(log, baseSpc, time, &base_space_pure_relation, &base_space_xdev)) {
|
|
|
|
return false;
|
|
|
|
}
|
2022-03-01 01:55:43 +00:00
|
|
|
|
|
|
|
struct xrt_relation_chain xrc = {0};
|
|
|
|
m_relation_chain_push_relation(&xrc, &space_pure_relation);
|
|
|
|
m_relation_chain_push_inverted_relation(&xrc, &base_space_pure_relation);
|
|
|
|
m_relation_chain_resolve(&xrc, out_relation);
|
2019-08-16 22:02:18 +00:00
|
|
|
|
2022-03-11 00:19:37 +00:00
|
|
|
return true;
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2019-10-22 10:47:25 +00:00
|
|
|
print_pose(struct oxr_session *sess, const char *prefix, struct xrt_pose *pose)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-10-22 10:47:25 +00:00
|
|
|
if (!sess->sys->inst->debug_spaces) {
|
2019-03-18 05:52:32 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct xrt_vec3 *p = &pose->position;
|
|
|
|
struct xrt_quat *q = &pose->orientation;
|
|
|
|
|
2021-01-14 14:13:48 +00:00
|
|
|
U_LOG_D("%s (%f, %f, %f) (%f, %f, %f, %f)", prefix, p->x, p->y, p->z, q->x, q->y, q->z, q->w);
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
|
2020-10-12 00:09:19 +00:00
|
|
|
XrSpaceLocationFlags
|
|
|
|
xrt_to_xr_space_location_flags(enum xrt_space_relation_flags relation_flags)
|
2020-05-28 23:42:54 +00:00
|
|
|
{
|
|
|
|
// clang-format off
|
|
|
|
bool valid_ori = (relation_flags & XRT_SPACE_RELATION_ORIENTATION_VALID_BIT) != 0;
|
|
|
|
bool tracked_ori = (relation_flags & XRT_SPACE_RELATION_ORIENTATION_TRACKED_BIT) != 0;
|
|
|
|
bool valid_pos = (relation_flags & XRT_SPACE_RELATION_POSITION_VALID_BIT) != 0;
|
|
|
|
bool tracked_pos = (relation_flags & XRT_SPACE_RELATION_POSITION_TRACKED_BIT) != 0;
|
2020-06-22 18:41:27 +00:00
|
|
|
|
|
|
|
bool linear_vel = (relation_flags & XRT_SPACE_RELATION_LINEAR_VELOCITY_VALID_BIT) != 0;
|
|
|
|
bool angular_vel = (relation_flags & XRT_SPACE_RELATION_ANGULAR_VELOCITY_VALID_BIT) != 0;
|
2020-05-28 23:42:54 +00:00
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
XrSpaceLocationFlags location_flags = (XrSpaceLocationFlags)0;
|
|
|
|
if (valid_ori) {
|
|
|
|
location_flags |= XR_SPACE_LOCATION_ORIENTATION_VALID_BIT;
|
|
|
|
}
|
|
|
|
if (tracked_ori) {
|
|
|
|
location_flags |= XR_SPACE_LOCATION_ORIENTATION_TRACKED_BIT;
|
|
|
|
}
|
|
|
|
if (valid_pos) {
|
|
|
|
location_flags |= XR_SPACE_LOCATION_POSITION_VALID_BIT;
|
|
|
|
}
|
|
|
|
if (tracked_pos) {
|
|
|
|
location_flags |= XR_SPACE_LOCATION_POSITION_TRACKED_BIT;
|
|
|
|
}
|
2020-06-22 18:41:27 +00:00
|
|
|
if (linear_vel) {
|
|
|
|
location_flags |= XR_SPACE_VELOCITY_LINEAR_VALID_BIT;
|
|
|
|
}
|
|
|
|
if (angular_vel) {
|
|
|
|
location_flags |= XR_SPACE_VELOCITY_ANGULAR_VALID_BIT;
|
|
|
|
}
|
2020-05-28 23:42:54 +00:00
|
|
|
return location_flags;
|
|
|
|
}
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
XrResult
|
2021-01-14 14:13:48 +00:00
|
|
|
oxr_space_locate(
|
|
|
|
struct oxr_logger *log, struct oxr_space *spc, struct oxr_space *baseSpc, XrTime time, XrSpaceLocation *location)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2022-03-14 16:14:57 +00:00
|
|
|
struct oxr_sink_logger slog = {0};
|
|
|
|
bool print = spc->sess->sys->inst->debug_spaces;
|
|
|
|
if (print) {
|
2022-04-10 16:41:49 +00:00
|
|
|
oxr_pp_space_indented(&slog, spc, "space");
|
|
|
|
oxr_pp_space_indented(&slog, baseSpc, "baseSpace");
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
|
2022-03-14 23:04:28 +00:00
|
|
|
// Used in a lot of places.
|
2022-03-25 14:29:15 +00:00
|
|
|
XrSpaceVelocity *vel = OXR_GET_OUTPUT_FROM_CHAIN(location->next, XR_TYPE_SPACE_VELOCITY, XrSpaceVelocity);
|
2022-03-14 23:04:28 +00:00
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
// Get the pure space relation.
|
|
|
|
struct xrt_space_relation pure;
|
2022-03-11 00:19:37 +00:00
|
|
|
bool has_pure_relation = get_pure_space_relation(log, spc, baseSpc, time, &pure);
|
|
|
|
if (!has_pure_relation) {
|
2019-07-13 16:17:57 +00:00
|
|
|
location->locationFlags = 0;
|
2022-03-14 16:11:18 +00:00
|
|
|
|
2022-03-14 23:04:07 +00:00
|
|
|
OXR_XRT_POSE_TO_XRPOSEF(XRT_POSE_IDENTITY, location->pose);
|
2022-03-14 16:11:18 +00:00
|
|
|
|
|
|
|
if (vel) {
|
|
|
|
vel->velocityFlags = 0;
|
|
|
|
U_ZERO(&vel->linearVelocity);
|
|
|
|
U_ZERO(&vel->angularVelocity);
|
|
|
|
}
|
|
|
|
|
2022-03-14 16:14:57 +00:00
|
|
|
if (print) {
|
|
|
|
oxr_slog(&slog, "\n\tReturning invalid pose");
|
|
|
|
oxr_log_slog(log, &slog);
|
|
|
|
} else {
|
2022-05-17 20:27:50 +00:00
|
|
|
oxr_slog_cancel(&slog);
|
2022-03-14 16:14:57 +00:00
|
|
|
}
|
|
|
|
|
2022-03-11 00:19:37 +00:00
|
|
|
return XR_SUCCESS;
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
|
2022-03-11 00:19:37 +00:00
|
|
|
|
2022-03-14 23:07:51 +00:00
|
|
|
/*
|
|
|
|
* Combine and copy
|
|
|
|
*/
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
// Combine space and base space poses with pure relation
|
|
|
|
struct xrt_space_relation result;
|
2022-01-21 15:58:44 +00:00
|
|
|
struct xrt_relation_chain xrc = {0};
|
|
|
|
m_relation_chain_push_pose_if_not_identity(&xrc, &spc->pose);
|
|
|
|
m_relation_chain_push_relation(&xrc, &pure);
|
|
|
|
m_relation_chain_push_inverted_pose_if_not_identity(&xrc, &baseSpc->pose);
|
|
|
|
m_relation_chain_resolve(&xrc, &result);
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2022-03-14 23:04:07 +00:00
|
|
|
OXR_XRT_POSE_TO_XRPOSEF(result.pose, location->pose);
|
2021-01-14 14:13:48 +00:00
|
|
|
location->locationFlags = xrt_to_xr_space_location_flags(result.relation_flags);
|
2019-09-06 14:35:41 +00:00
|
|
|
|
2020-06-22 18:41:27 +00:00
|
|
|
if (vel) {
|
2022-03-14 22:04:02 +00:00
|
|
|
vel->velocityFlags = 0;
|
|
|
|
if ((result.relation_flags & XRT_SPACE_RELATION_LINEAR_VELOCITY_VALID_BIT) != 0) {
|
|
|
|
vel->linearVelocity.x = result.linear_velocity.x;
|
|
|
|
vel->linearVelocity.y = result.linear_velocity.y;
|
|
|
|
vel->linearVelocity.z = result.linear_velocity.z;
|
|
|
|
vel->velocityFlags |= XR_SPACE_VELOCITY_LINEAR_VALID_BIT;
|
|
|
|
} else {
|
|
|
|
U_ZERO(&vel->linearVelocity);
|
|
|
|
}
|
2020-06-22 18:41:27 +00:00
|
|
|
|
2022-03-14 22:04:02 +00:00
|
|
|
if ((result.relation_flags & XRT_SPACE_RELATION_ANGULAR_VELOCITY_VALID_BIT) != 0) {
|
|
|
|
vel->angularVelocity.x = result.angular_velocity.x;
|
|
|
|
vel->angularVelocity.y = result.angular_velocity.y;
|
|
|
|
vel->angularVelocity.z = result.angular_velocity.z;
|
|
|
|
vel->velocityFlags |= XR_SPACE_VELOCITY_ANGULAR_VALID_BIT;
|
|
|
|
} else {
|
|
|
|
U_ZERO(&vel->angularVelocity);
|
|
|
|
}
|
2020-06-22 18:41:27 +00:00
|
|
|
}
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2022-03-14 23:07:51 +00:00
|
|
|
/*
|
|
|
|
* Print
|
|
|
|
*/
|
2022-03-14 16:14:57 +00:00
|
|
|
|
|
|
|
if (print) {
|
2022-04-10 16:41:49 +00:00
|
|
|
oxr_pp_pose_indented_as_object(&slog, (struct xrt_pose *)&pure.pose, "pure");
|
|
|
|
oxr_pp_relation_indented(&slog, &result, "relation");
|
2022-03-14 16:14:57 +00:00
|
|
|
oxr_log_slog(log, &slog);
|
|
|
|
} else {
|
2022-05-17 20:27:50 +00:00
|
|
|
oxr_slog_cancel(&slog);
|
2022-03-14 16:14:57 +00:00
|
|
|
}
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2019-09-26 20:25:05 +00:00
|
|
|
return oxr_session_success_result(spc->sess);
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|