qadmesh affine transform parenting

This commit is contained in:
AndreaRigoni
2026-03-19 12:54:31 +00:00
parent 887b3b36f0
commit 4cb4560921
9 changed files with 103 additions and 33 deletions

View File

@@ -29,25 +29,33 @@
#include <vector>
#include "Math/Dense.h"
#include "Core/Object.h"
#include "Math/Transform.h"
namespace uLib {
class QuadMesh
class QuadMesh : public AffineTransform, public Object
{
public:
void PrintSelf(std::ostream &o);
/** @brief Adds a point in global coordinates. Stored in local coordinates. */
void AddPoint(const Vector3f &pt);
void AddQuad(const Id_t *id);
void AddQuad(const Vector4i &id);
/** @brief Returns point in global coordinates. */
Vector3f GetPoint(const Id_t id) const;
inline std::vector<Vector3f> & Points() { return this->m_Points; }
inline std::vector<Vector4i> & Quads() { return this->m_Quads; }
const Vector4i & GetQuad(const Id_t id) const { return m_Quads.at(id); }
Vector3f GetNormal(const Id_t id) const;
virtual void Updated() override { ULIB_SIGNAL_EMIT(QuadMesh::Updated); }
private:
std::vector<Vector3f> m_Points;
std::vector<Vector4i> m_Quads;