monado/src/xrt/auxiliary/util/u_distortion_mesh.h

230 lines
4.5 KiB
C

// Copyright 2019, Collabora, Ltd.
// SPDX-License-Identifier: BSL-1.0
/*!
* @file
* @brief Code to generate disortion meshes.
* @author Jakob Bornecrantz <jakob@collabora.com>
* @author Moses Turner <moses@collabora.com>
* @ingroup aux_distortion
*/
#pragma once
#include "xrt/xrt_device.h"
#include "xrt/xrt_defines.h"
#include "util/u_distortion.h"
#ifdef __cplusplus
extern "C" {
#endif
/*
*
* Panotools distortion
*
*/
/*!
* Values to create a distortion mesh from panotools values.
*
* @ingroup aux_distortion
*/
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;
};
/*!
* Distortion correction implementation for Panotools distortion values.
*
* @ingroup aux_distortion
*/
bool
u_compute_distortion_panotools(struct u_panotools_values *values, float u, float v, struct xrt_uv_triplet *result);
/*
*
* Vive, Vive Pro & Index distortion
*
*/
/*!
* Values to create a distortion mesh from Vive configuration values.
*
* @ingroup aux_distortion
*/
struct u_vive_values
{
float aspect_x_over_y;
float grow_for_undistort;
float undistort_r2_cutoff;
//! r/g/b
struct xrt_vec2 center[3];
//! r/g/b, a/b/c/d
float coefficients[3][4];
};
/*!
* Distortion correction implementation for the Vive, Vive Pro, Valve Index
* distortion values found in the HMD configuration.
*
* @ingroup aux_distortion
*/
bool
u_compute_distortion_vive(struct u_vive_values *values, float u, float v, struct xrt_uv_triplet *result);
/*
*
* 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);
/*
*
* North Star 2D/Polynomial distortion.
*
*/
struct u_ns_p2d_values
{
float x_coefficients_left[16];
float x_coefficients_right[16];
float y_coefficients_left[16];
float y_coefficients_right[16];
struct xrt_fov fov[2]; // left, right
float ipd;
};
/*!
* Distortion correction implementation for North Star 2D/Polynomial.
*
* @ingroup aux_distortion
*/
bool
u_compute_distortion_ns_p2d(struct u_ns_p2d_values *values, int view, float u, float v, struct xrt_uv_triplet *result);
/*
*
* North Star 2D/"VIPD" distortion.
*
*/
struct u_ns_vipd_grid
{
struct xrt_vec2 grid[2][65][65];
};
struct u_ns_vipd_values
{
int number_of_ipds;
float *ipds;
struct u_ns_vipd_grid *grids;
struct u_ns_vipd_grid grid_for_use;
struct xrt_fov fov[2]; // left, right
float ipd;
};
/*!
* Distortion correction implementation for North Star 2D/"VIPD".
*
* @ingroup aux_distortion
*/
bool
u_compute_distortion_ns_vipd(
struct u_ns_vipd_values *values, int view, float u, float v, struct xrt_uv_triplet *result);
/*
*
* None distortion
*
*/
/*!
* Identity distortion correction sets all result coordinates to u,v.
*
* @ingroup aux_distortion
*/
bool
u_compute_distortion_none(float u, float v, struct xrt_uv_triplet *result);
/*!
* Helper function for none distortion devices.
*
* @ingroup aux_distortion
*/
bool
u_distortion_mesh_none(struct xrt_device *xdev, int view, float u, float v, struct xrt_uv_triplet *result);
/*
*
* Mesh generation functions.
*
*/
/*!
* Given a @ref xrt_device generates meshes by calling
* xdev->compute_distortion(), populates `xdev->hmd_parts.distortion.mesh` &
* `xdev->hmd_parts.distortion.models`.
*
* @relatesalso xrt_device
* @ingroup aux_distortion
*/
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`.
*
* @relatesalso xrt_device
* @ingroup aux_distortion
*/
void
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
* @ingroup aux_distortion
*/
void
u_distortion_mesh_set_none(struct xrt_device *xdev);
#ifdef __cplusplus
}
#endif