mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 21:28:50 +00:00
a/vive: Add common header with documentation [NFC]
This commit is contained in:
parent
287102d256
commit
205d82ce9c
|
@ -5,7 +5,7 @@
|
||||||
* @brief Shared bindings structs for @ref drv_vive & @ref drv_survive.
|
* @brief Shared bindings structs for @ref drv_vive & @ref drv_survive.
|
||||||
* @author Christoph Haag <christoph.haag@collabora.com>
|
* @author Christoph Haag <christoph.haag@collabora.com>
|
||||||
* @author Jakob Bornecrantz <jakob@collabora.com>
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "vive/vive_bindings.h"
|
#include "vive/vive_bindings.h"
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
* @brief Shared bindings structs for @ref drv_vive & @ref drv_survive.
|
* @brief Shared bindings structs for @ref drv_vive & @ref drv_survive.
|
||||||
* @author Christoph Haag <christoph.haag@collabora.com>
|
* @author Christoph Haag <christoph.haag@collabora.com>
|
||||||
* @author Jakob Bornecrantz <jakob@collabora.com>
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
* @brief Vive calibration getters.
|
* @brief Vive calibration getters.
|
||||||
* @author Mateo de Mayo <mateo.demayo@collabora.com>
|
* @author Mateo de Mayo <mateo.demayo@collabora.com>
|
||||||
* @author Moses Turner <moses@collabora.com>
|
* @author Moses Turner <moses@collabora.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
* @brief Vive calibration getters.
|
* @brief Vive calibration getters.
|
||||||
* @author Mateo de Mayo <mateo.demayo@collabora.com>
|
* @author Mateo de Mayo <mateo.demayo@collabora.com>
|
||||||
* @author Moses Turner <moses@collabora.com>
|
* @author Moses Turner <moses@collabora.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
@ -24,7 +24,7 @@ struct vive_config;
|
||||||
/*!
|
/*!
|
||||||
* Get a @ref t_stereo_camera_calibration and @ref xrt_pose from left camera to head translation.
|
* Get a @ref t_stereo_camera_calibration and @ref xrt_pose from left camera to head translation.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
bool
|
bool
|
||||||
vive_get_stereo_camera_calibration(const struct vive_config *d,
|
vive_get_stereo_camera_calibration(const struct vive_config *d,
|
||||||
|
@ -34,7 +34,7 @@ vive_get_stereo_camera_calibration(const struct vive_config *d,
|
||||||
/*!
|
/*!
|
||||||
* Get a @ref t_slam_camera_calibration one for each camera.
|
* Get a @ref t_slam_camera_calibration one for each camera.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
vive_get_slam_cams_calib(const struct vive_config *d,
|
vive_get_slam_cams_calib(const struct vive_config *d,
|
||||||
|
@ -44,7 +44,7 @@ vive_get_slam_cams_calib(const struct vive_config *d,
|
||||||
/*!
|
/*!
|
||||||
* Get a @ref t_imu_calibration for the IMU.
|
* Get a @ref t_imu_calibration for the IMU.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
vive_get_imu_calibration(const struct vive_config *d, struct t_imu_calibration *out_calib);
|
vive_get_imu_calibration(const struct vive_config *d, struct t_imu_calibration *out_calib);
|
||||||
|
@ -52,7 +52,7 @@ vive_get_imu_calibration(const struct vive_config *d, struct t_imu_calibration *
|
||||||
/*!
|
/*!
|
||||||
* Get a @ref t_slam_imu_calibration for the IMU.
|
* Get a @ref t_slam_imu_calibration for the IMU.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
vive_get_slam_imu_calibration(const struct vive_config *d, struct t_slam_imu_calibration *out_calib);
|
vive_get_slam_imu_calibration(const struct vive_config *d, struct t_slam_imu_calibration *out_calib);
|
||||||
|
|
37
src/xrt/auxiliary/vive/vive_common.h
Normal file
37
src/xrt/auxiliary/vive/vive_common.h
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
// Copyright 2020-2023, Collabora, Ltd.
|
||||||
|
// SPDX-License-Identifier: BSL-1.0
|
||||||
|
/*!
|
||||||
|
* @file
|
||||||
|
* @brief Common things like defines for Vive and Index.
|
||||||
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
||||||
|
* @ingroup aux_vive
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "xrt/xrt_compiler.h"
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @defgroup aux_vive Shared code for @ref drv_vive and @ref drv_survive.
|
||||||
|
* @ingroup aux
|
||||||
|
*
|
||||||
|
* @brief Shared functionality for @ref drv_vive and @ref drv_survive drivers
|
||||||
|
* that supports the HTC Vive and Valve Index family of HMDs.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @dir auxiliary/vive
|
||||||
|
*
|
||||||
|
* @brief @ref aux_vive files.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
|
@ -5,7 +5,7 @@
|
||||||
* @brief Vive json implementation
|
* @brief Vive json implementation
|
||||||
* @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
|
* @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
|
||||||
* @author Moses Turner <moses@collabora.com>
|
* @author Moses Turner <moses@collabora.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
* @brief vive json header
|
* @brief vive json header
|
||||||
* @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
|
* @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
|
||||||
* @author Moses Turner <moses@collabora.com>
|
* @author Moses Turner <moses@collabora.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
@ -41,7 +41,7 @@ extern "C" {
|
||||||
/*!
|
/*!
|
||||||
* Headset variant.
|
* Headset variant.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
enum VIVE_VARIANT
|
enum VIVE_VARIANT
|
||||||
{
|
{
|
||||||
|
@ -54,7 +54,7 @@ enum VIVE_VARIANT
|
||||||
/*!
|
/*!
|
||||||
* Controller variant.
|
* Controller variant.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
enum VIVE_CONTROLLER_VARIANT
|
enum VIVE_CONTROLLER_VARIANT
|
||||||
{
|
{
|
||||||
|
@ -69,7 +69,7 @@ enum VIVE_CONTROLLER_VARIANT
|
||||||
/*!
|
/*!
|
||||||
* A calibrated camera on an Index.
|
* A calibrated camera on an Index.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
struct index_camera
|
struct index_camera
|
||||||
{
|
{
|
||||||
|
@ -108,7 +108,7 @@ struct index_camera
|
||||||
/*!
|
/*!
|
||||||
* A single lighthouse senosor point and normal, in IMU space.
|
* A single lighthouse senosor point and normal, in IMU space.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
struct lh_sensor
|
struct lh_sensor
|
||||||
{
|
{
|
||||||
|
@ -123,7 +123,7 @@ struct lh_sensor
|
||||||
*
|
*
|
||||||
* All sensors are placed in IMU space.
|
* All sensors are placed in IMU space.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
struct lh_model
|
struct lh_model
|
||||||
{
|
{
|
||||||
|
@ -134,7 +134,7 @@ struct lh_model
|
||||||
/*!
|
/*!
|
||||||
* headset config.
|
* headset config.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
struct vive_config
|
struct vive_config
|
||||||
{
|
{
|
||||||
|
@ -211,7 +211,7 @@ struct vive_config
|
||||||
/*!
|
/*!
|
||||||
* Controller config.
|
* Controller config.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
struct vive_controller_config
|
struct vive_controller_config
|
||||||
{
|
{
|
||||||
|
@ -255,7 +255,7 @@ struct vive_controller_config
|
||||||
/*!
|
/*!
|
||||||
* Parse a headset config.
|
* Parse a headset config.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
bool
|
bool
|
||||||
vive_config_parse(struct vive_config *d, char *json_string, enum u_logging_level log_level);
|
vive_config_parse(struct vive_config *d, char *json_string, enum u_logging_level log_level);
|
||||||
|
@ -263,7 +263,7 @@ vive_config_parse(struct vive_config *d, char *json_string, enum u_logging_level
|
||||||
/*!
|
/*!
|
||||||
* Free any allocated resources on this config.
|
* Free any allocated resources on this config.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
vive_config_teardown(struct vive_config *config);
|
vive_config_teardown(struct vive_config *config);
|
||||||
|
@ -271,7 +271,7 @@ vive_config_teardown(struct vive_config *config);
|
||||||
/*!
|
/*!
|
||||||
* Parse a controller config.
|
* Parse a controller config.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
bool
|
bool
|
||||||
vive_config_parse_controller(struct vive_controller_config *d, char *json_string, enum u_logging_level log_level);
|
vive_config_parse_controller(struct vive_controller_config *d, char *json_string, enum u_logging_level log_level);
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
* @file
|
* @file
|
||||||
* @brief Vive poses implementation
|
* @brief Vive poses implementation
|
||||||
* @author Daniel Willmott <web@dan-w.com>
|
* @author Daniel Willmott <web@dan-w.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "vive_poses.h"
|
#include "vive_poses.h"
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
* @file
|
* @file
|
||||||
* @brief vive poses header
|
* @brief vive poses header
|
||||||
* @author Daniel Willmott <web@dan-w.com>
|
* @author Daniel Willmott <web@dan-w.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
* @file
|
* @file
|
||||||
* @brief Tweaks for various bits on Vive and Index headsets.
|
* @brief Tweaks for various bits on Vive and Index headsets.
|
||||||
* @author Jakob Bornecrantz <jakob@collabora.com>
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "xrt/xrt_defines.h"
|
#include "xrt/xrt_defines.h"
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
* @file
|
* @file
|
||||||
* @brief Tweaks for various bits on Vive and Index headsets.
|
* @brief Tweaks for various bits on Vive and Index headsets.
|
||||||
* @author Jakob Bornecrantz <jakob@collabora.com>
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
@ -22,7 +22,7 @@ struct vive_config;
|
||||||
/*!
|
/*!
|
||||||
* Tweak the fov for the views on the given config, to make it better.
|
* Tweak the fov for the views on the given config, to make it better.
|
||||||
*
|
*
|
||||||
* @ingroup drv_vive
|
* @ingroup aux_vive
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
vive_tweak_fov(struct vive_config *config);
|
vive_tweak_fov(struct vive_config *config);
|
||||||
|
|
Loading…
Reference in a new issue