bgfx/examples/common/bounds.h

128 lines
3.3 KiB
C
Raw Normal View History

2013-02-22 00:07:31 -05:00
/*
2016-01-01 03:11:04 -05:00
* Copyright 2011-2016 Branimir Karadzic. All rights reserved.
* License: https://github.com/bkaradzic/bgfx#license-bsd-2-clause
2013-02-22 00:07:31 -05:00
*/
#ifndef BOUNDS_H_HEADER_GUARD
#define BOUNDS_H_HEADER_GUARD
2013-02-22 00:07:31 -05:00
struct Aabb
{
float m_min[3];
float m_max[3];
};
2015-11-28 02:45:42 -05:00
struct Cylinder
{
float m_pos[3];
float m_end[3];
float m_radius;
};
struct Disk
{
float m_center[3];
float m_normal[3];
float m_radius;
};
2013-02-22 00:07:31 -05:00
struct Obb
{
float m_mtx[16];
};
2015-11-28 02:45:42 -05:00
struct Plane
{
float m_normal[3];
float m_dist;
};
struct Ray
{
float m_pos[3];
float m_dir[3];
};
2013-02-22 00:07:31 -05:00
struct Sphere
{
float m_center[3];
float m_radius;
};
2015-11-28 02:45:42 -05:00
struct Tris
{
float m_v0[3];
float m_v1[3];
float m_v2[3];
};
struct Intersection
{
float m_pos[3];
float m_normal[3];
float m_dist;
};
2013-02-22 00:07:31 -05:00
/// Convert axis aligned bounding box to oriented bounding box.
void aabbToObb(Obb& _obb, const Aabb& _aabb);
2014-05-20 01:08:35 -04:00
/// Convert sphere to axis aligned bounding box.
void sphereToAabb(Aabb& _aabb, const Sphere& _sphere);
2013-02-22 00:07:31 -05:00
/// Calculate surface area of axis aligned bounding box.
float calcAabbArea(Aabb& _aabb);
/// Calculate axis aligned bounding box.
void calcAabb(Aabb& _aabb, const void* _vertices, uint32_t _numVertices, uint32_t _stride);
/// Transform vertices and calculate axis aligned bounding box.
void calcAabb(Aabb& _aabb, const float* _mtx, const void* _vertices, uint32_t _numVertices, uint32_t _stride);
2014-05-26 19:55:46 -04:00
/// Expand AABB.
void aabbExpand(Aabb& _aabb, float _factor);
/// Returns 0 is two AABB don't overlap, otherwise returns flags of overlap
/// test.
2015-11-28 02:45:42 -05:00
uint32_t aabbOverlapTest(const Aabb& _aabb0, const Aabb& _aabb1);
2014-05-26 19:55:46 -04:00
2013-02-22 00:07:31 -05:00
/// Calculate oriented bounding box.
void calcObb(Obb& _obb, const void* _vertices, uint32_t _numVertices, uint32_t _stride, uint32_t _steps = 17);
/// Calculate maximum bounding sphere.
void calcMaxBoundingSphere(Sphere& _sphere, const void* _vertices, uint32_t _numVertices, uint32_t _stride);
/// Calculate minimum bounding sphere.
void calcMinBoundingSphere(Sphere& _sphere, const void* _vertices, uint32_t _numVertices, uint32_t _stride, float _step = 0.01f);
2016-02-21 15:57:55 -05:00
/// Calculate coplanar U/V vectors.
void calcPlaneUv(const Plane& _plane, float _step, float* _udir, float* _vdir);
/// Returns 6 (near, far, left, right, top, bottom) planes representing frustum planes.
void buildFrustumPlanes(Plane* _planes, const float* _viewProj);
/// Returns point from 3 intersecting planes.
void intersectPlanes(float _result[3], const Plane& _pa, const Plane& _pb, const Plane& _pc);
2015-11-28 02:45:42 -05:00
/// Make screen space ray from x, y coordinate and inverse view-projection matrix.
Ray makeRay(float _x, float _y, const float* _invVp);
/// Intersect ray / aabb.
bool intersect(const Ray& _ray, const Aabb& _aabb, Intersection* _intersection = NULL);
/// Intersect ray / cylinder.
bool intersect(const Ray& _ray, const Cylinder& _cylinder, bool _capsule, Intersection* _intersection = NULL);
/// Intersect ray / disk.
bool intersect(const Ray& _ray, const Disk& _disk, Intersection* _intersection = NULL);
/// Intersect ray / plane.
bool intersect(const Ray& _ray, const Plane& _plane, Intersection* _intersection = NULL);
/// Intersect ray / sphere.
bool intersect(const Ray& _ray, const Sphere& _sphere, Intersection* _intersection = NULL);
/// Intersect ray / triangle.
bool intersect(const Ray& _ray, const Tris& _triangle, Intersection* _intersection = NULL);
#endif // BOUNDS_H_HEADER_GUARD