mirror of
https://github.com/RetroDECK/Supermodel.git
synced 2024-11-26 23:55:40 +00:00
28 lines
425 B
C++
28 lines
425 B
C++
#ifndef _PLANE_H_
|
|
#define _PLANE_H_
|
|
|
|
#include <cmath>
|
|
|
|
struct Plane
|
|
{
|
|
float a, b, c, d;
|
|
|
|
void Normalise() {
|
|
float temp = 1.f/std::sqrt((a * a) + (b * b) + (c * c));
|
|
a *= temp;
|
|
b *= temp;
|
|
c *= temp;
|
|
d *= temp;
|
|
}
|
|
|
|
float DistanceToPoint(const float v[3]) {
|
|
return a*v[0] + b*v[1] + c*v[2] + d;
|
|
}
|
|
|
|
float DotProduct(const float v[3]) {
|
|
return a*v[0] + b*v[1] + c*v[2];
|
|
}
|
|
};
|
|
|
|
#endif
|