2019-10-22 17:45:25 +00:00
|
|
|
// Copyright 2019, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Code to generate disortion meshes.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
2020-10-25 01:12:11 +00:00
|
|
|
* @ingroup aux_distortion
|
2019-10-22 17:45:25 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "xrt/xrt_device.h"
|
|
|
|
#include "xrt/xrt_defines.h"
|
|
|
|
|
2020-10-25 01:12:11 +00:00
|
|
|
#include "util/u_distortion.h"
|
|
|
|
|
|
|
|
|
2019-10-22 17:45:25 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-10-24 14:36:50 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Panotools distortion
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Values to create a distortion mesh from panotools values.
|
2020-10-25 01:12:11 +00:00
|
|
|
*
|
|
|
|
* @ingroup aux_distortion
|
2019-10-22 17:45:25 +00:00
|
|
|
*/
|
|
|
|
struct u_panotools_values
|
|
|
|
{
|
|
|
|
//! Panotools universal distortion k (reverse order from OpenHMD).
|
|
|
|
float distortion_k[5];
|
|
|
|
//! Panotools post distortion scale, <r, g, b>.
|
|
|
|
float aberration_k[3];
|
|
|
|
//! Panotools warp scale.
|
|
|
|
float scale;
|
|
|
|
//! Center of the lens.
|
|
|
|
struct xrt_vec2 lens_center;
|
|
|
|
//! Viewport size.
|
|
|
|
struct xrt_vec2 viewport_size;
|
|
|
|
};
|
|
|
|
|
2020-09-29 01:55:38 +00:00
|
|
|
/*!
|
2020-10-24 14:36:50 +00:00
|
|
|
* Distortion correction implementation for Panotools distortion values.
|
2020-10-25 01:12:11 +00:00
|
|
|
*
|
|
|
|
* @ingroup aux_distortion
|
2020-10-24 14:36:50 +00:00
|
|
|
*/
|
|
|
|
bool
|
2021-01-14 14:13:48 +00:00
|
|
|
u_compute_distortion_panotools(struct u_panotools_values *values, float u, float v, struct xrt_uv_triplet *result);
|
2020-10-24 14:36:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Vive, Vive Pro & Index distortion
|
2020-09-29 01:55:38 +00:00
|
|
|
*
|
2020-10-24 14:36:50 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Values to create a distortion mesh from Vive configuration values.
|
2020-10-25 01:12:11 +00:00
|
|
|
*
|
|
|
|
* @ingroup aux_distortion
|
2020-09-29 01:55:38 +00:00
|
|
|
*/
|
|
|
|
struct u_vive_values
|
|
|
|
{
|
|
|
|
float aspect_x_over_y;
|
|
|
|
float grow_for_undistort;
|
|
|
|
|
2020-09-29 17:08:21 +00:00
|
|
|
float undistort_r2_cutoff;
|
2020-09-29 01:55:38 +00:00
|
|
|
|
2021-01-23 23:19:06 +00:00
|
|
|
//! r/g/b
|
|
|
|
struct xrt_vec2 center[3];
|
2020-09-29 01:55:38 +00:00
|
|
|
|
2021-01-23 23:19:06 +00:00
|
|
|
//! r/g/b, a/b/c
|
2020-09-29 17:08:21 +00:00
|
|
|
float coefficients[3][3];
|
2020-09-29 01:55:38 +00:00
|
|
|
};
|
|
|
|
|
2020-09-29 17:08:21 +00:00
|
|
|
/*!
|
|
|
|
* Distortion correction implementation for the Vive, Vive Pro, Valve Index
|
|
|
|
* distortion values found in the HMD configuration.
|
2020-10-25 01:12:11 +00:00
|
|
|
*
|
|
|
|
* @ingroup aux_distortion
|
2020-09-29 17:08:21 +00:00
|
|
|
*/
|
|
|
|
bool
|
2021-01-14 14:13:48 +00:00
|
|
|
u_compute_distortion_vive(struct u_vive_values *values, float u, float v, struct xrt_uv_triplet *result);
|
2020-09-29 17:08:21 +00:00
|
|
|
|
2020-10-24 14:36:50 +00:00
|
|
|
|
2020-10-25 01:12:11 +00:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Cardboard mesh distortion parameters.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Distortion correction implementation for the Cardboard devices.
|
|
|
|
*
|
|
|
|
* @ingroup aux_distortion
|
|
|
|
*/
|
|
|
|
bool
|
|
|
|
u_compute_distortion_cardboard(struct u_cardboard_distortion_values *values,
|
|
|
|
float u,
|
|
|
|
float v,
|
|
|
|
struct xrt_uv_triplet *result);
|
|
|
|
|
|
|
|
|
2020-10-24 14:36:50 +00:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* None distortion
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-01-26 16:00:14 +00:00
|
|
|
/*!
|
2020-08-12 18:32:07 +00:00
|
|
|
* Identity distortion correction sets all result coordinates to u,v.
|
2020-10-25 01:12:11 +00:00
|
|
|
*
|
|
|
|
* @ingroup aux_distortion
|
2019-10-22 17:45:25 +00:00
|
|
|
*/
|
2020-08-12 18:32:07 +00:00
|
|
|
bool
|
2020-09-30 14:35:57 +00:00
|
|
|
u_compute_distortion_none(float u, float v, struct xrt_uv_triplet *result);
|
2019-10-22 17:45:25 +00:00
|
|
|
|
2020-10-07 15:49:02 +00:00
|
|
|
/*!
|
|
|
|
* Helper function for none distortion devices.
|
2020-10-25 01:12:11 +00:00
|
|
|
*
|
|
|
|
* @ingroup aux_distortion
|
2020-10-07 15:49:02 +00:00
|
|
|
*/
|
|
|
|
bool
|
2021-01-14 14:13:48 +00:00
|
|
|
u_distortion_mesh_none(struct xrt_device *xdev, int view, float u, float v, struct xrt_uv_triplet *result);
|
2020-10-07 15:49:02 +00:00
|
|
|
|
|
|
|
|
2020-10-24 14:36:50 +00:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Mesh generation functions.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-10-22 17:45:25 +00:00
|
|
|
/*!
|
2020-08-12 18:32:07 +00:00
|
|
|
* Given a @ref xrt_device generates meshes by calling
|
2020-10-07 15:49:02 +00:00
|
|
|
* xdev->compute_distortion(), populates `xdev->hmd_parts.distortion.mesh` &
|
|
|
|
* `xdev->hmd_parts.distortion.models`.
|
|
|
|
*
|
|
|
|
* @relatesalso xrt_device
|
2020-10-25 01:12:11 +00:00
|
|
|
* @ingroup aux_distortion
|
2020-10-07 15:49:02 +00:00
|
|
|
*/
|
|
|
|
void
|
|
|
|
u_distortion_mesh_fill_in_compute(struct xrt_device *xdev);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Given a @ref xrt_device generates a no distortion mesh, populates
|
|
|
|
* `xdev->hmd_parts.distortion.mesh` & `xdev->hmd_parts.distortion.models`.
|
2019-10-22 17:45:25 +00:00
|
|
|
*
|
2020-08-12 18:32:07 +00:00
|
|
|
* @relatesalso xrt_device
|
2020-10-25 01:12:11 +00:00
|
|
|
* @ingroup aux_distortion
|
2019-10-22 17:45:25 +00:00
|
|
|
*/
|
|
|
|
void
|
2020-10-07 15:49:02 +00:00
|
|
|
u_distortion_mesh_fill_in_none(struct xrt_device *xdev);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Given a @ref xrt_device generates a no distortion mesh, also sets
|
|
|
|
* `xdev->compute_distortion()` and populates `xdev->hmd_parts.distortion.mesh`
|
|
|
|
* & `xdev->hmd_parts.distortion.models`.
|
|
|
|
*
|
|
|
|
* @relatesalso xrt_device
|
2020-10-25 01:12:11 +00:00
|
|
|
* @ingroup aux_distortion
|
2020-10-07 15:49:02 +00:00
|
|
|
*/
|
|
|
|
void
|
|
|
|
u_distortion_mesh_set_none(struct xrt_device *xdev);
|
|
|
|
|
2019-10-22 17:45:25 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|