From 5738b7da19097b4c75ee913022913286add8d603 Mon Sep 17 00:00:00 2001 From: Carl Woffenden Date: Sat, 27 May 2023 20:39:18 +0200 Subject: [PATCH] Added initial vertex colour support And verified by hand that they're read, at least from FBX. --- inc/objvertex.h | 1 + inc/vec.h | 1 + src/objvertex.cpp | 27 ++++++++++++++++++++++----- 3 files changed, 24 insertions(+), 5 deletions(-) diff --git a/inc/objvertex.h b/inc/objvertex.h index 5e82978..58a368c 100644 --- a/inc/objvertex.h +++ b/inc/objvertex.h @@ -79,6 +79,7 @@ struct ObjVertex vec3 norm; /**< Normals (from the \c .obj file). */ vec3 tans; /**< Tangents (generated if needed). */ vec3 btan; /**< Bitangents (generated if needed). */ + vec4 rgba; /**< Vertex colours (standard only in the FBX file). */ /** * An alternative to storing the bitangents is to recreate them from: * \code diff --git a/inc/vec.h b/inc/vec.h index d407234..06b2c31 100644 --- a/inc/vec.h +++ b/inc/vec.h @@ -294,6 +294,7 @@ struct Vec4 T y; T z; T w; + Vec4() {} Vec4& operator =(T const val) { x = val; y = val; diff --git a/src/objvertex.cpp b/src/objvertex.cpp index 26d09d5..6454a78 100644 --- a/src/objvertex.cpp +++ b/src/objvertex.cpp @@ -512,6 +512,22 @@ bool copyVec(const ufbx_vertex_vec3& src, size_t const idx, vec3& dst) { } return false; } +/** + * \copydoc copyVec(const ufbx_vertex_vec2&,size_t,vec2&) + */ +bool copyVec(const ufbx_vertex_vec4& src, size_t const idx, vec4& dst) { + if (src.exists) { + ufbx_vec4& vec = src.values.data[src.indices.data[idx]]; + dst.x = static_cast(vec.x); + dst.y = static_cast(vec.y); + dst.z = static_cast(vec.z); + dst.w = static_cast(vec.w); + return true; + } else { + dst = 0.0f; + } + return false; +} } //*****************************************************************************/ @@ -543,17 +559,18 @@ ObjVertex::ObjVertex(ufbx_mesh* fbx, size_t const idx) { * Initial attempt at this: all vertex data are copied, zeroing if they * don't exist (no effort has been made so far to generate missing data). * - * Note: we're currently reading this but then ignoring any tangents (since - * at a first glance they weren't correct) and recreating them. + * Note: we're recreating tangents (1. because they have the wrong + * orientation and need correcting, and 2. so that we have the same + * MikkTSpace calculations throughout). * * TODO: extract (and support) tex1 from ufbx_uv_set_list - * TODO: add support for vertex_color */ impl::copyVec(fbx->vertex_position, idx, posn); impl::copyVec(fbx->vertex_uv, idx, tex0); impl::copyVec(fbx->vertex_normal, idx, norm); - impl::copyVec(fbx->vertex_tangent, idx, tans); - impl::copyVec(fbx->vertex_bitangent, idx, btan); + impl::copyVec(fbx->vertex_color, idx, rgba); + tans = 0.0f; + btan = 0.0f; sign = 0.0f; }