// Copyright 2019, Collabora, Ltd. // SPDX-License-Identifier: BSL-1.0 /*! * @file * @brief Code to generate disortion meshes. * @author Jakob Bornecrantz * @ingroup aux_util */ #pragma once #include "xrt/xrt_device.h" #include "xrt/xrt_defines.h" #ifdef __cplusplus extern "C" { #endif /*! * Values to create a distortion mesh from panotools values. * * @ingroup aux_util */ struct u_panotools_values { //! Panotools universal distortion k (reverse order from OpenHMD). float distortion_k[5]; //! Panotools post distortion scale, . 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; }; /*! * Three UV pairs, one for each color channel in the source image. * * @ingroup aux_util */ struct u_uv_triplet { struct xrt_vec2 r, g, b; }; /*! * @interface u_uv_generator * * Generator interface for building meshes, can be implemented by drivers for * special meshes. * * @ingroup aux_util */ struct u_uv_generator { void (*calc)(struct u_uv_generator *, int view, float u, float v, struct u_uv_triplet *result); void (*destroy)(struct u_uv_generator *); }; /*! * Given a @ref u_uv_generator generates num_views meshes, populates target. * * @ingroup aux_util * @public @memberof u_uv_generator * @relatesalso xrt_hmd_parts */ void u_distortion_mesh_from_gen(struct u_uv_generator *, int num_views, struct xrt_hmd_parts *target); /*! * Given two sets of panotools values creates a mesh generator, copies the * values into it. This probably isn't the function you want. * * @ingroup aux_util * @see u_distortion_mesh_from_panotools */ void u_distortion_mesh_generator_from_panotools( const struct u_panotools_values *left, const struct u_panotools_values *right, struct u_uv_generator **out_gen); /*! * Given two sets of panotools values creates the left and th right uv meshes. * This is probably the function you want. * * @ingroup aux_util * @relates xrt_hmd_parts */ void u_distortion_mesh_from_panotools(const struct u_panotools_values *left, const struct u_panotools_values *right, struct xrt_hmd_parts *target); /*! * Create two distortion meshes with no distortion. * * @ingroup aux_util * @relates xrt_hmd_parts */ void u_distortion_mesh_none(struct xrt_hmd_parts *target); #ifdef __cplusplus } #endif