39 lines
1.1 KiB
C++
39 lines
1.1 KiB
C++
|
|
#pragma once
|
|
|
|
#include <cmath>
|
|
#include <cfloat>
|
|
#include "base.h"
|
|
|
|
namespace msdfgen {
|
|
|
|
/// Represents a signed distance and alignment, which together can be compared to uniquely determine the closest edge segment.
|
|
class SignedDistance {
|
|
|
|
public:
|
|
double distance;
|
|
double dot;
|
|
|
|
inline SignedDistance() : distance(-DBL_MAX), dot(0) { }
|
|
inline SignedDistance(double dist, double d) : distance(dist), dot(d) { }
|
|
|
|
};
|
|
|
|
inline bool operator<(const SignedDistance a, const SignedDistance b) {
|
|
return fabs(a.distance) < fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot < b.dot);
|
|
}
|
|
|
|
inline bool operator>(const SignedDistance a, const SignedDistance b) {
|
|
return fabs(a.distance) > fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot > b.dot);
|
|
}
|
|
|
|
inline bool operator<=(const SignedDistance a, const SignedDistance b) {
|
|
return fabs(a.distance) < fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot <= b.dot);
|
|
}
|
|
|
|
inline bool operator>=(const SignedDistance a, const SignedDistance b) {
|
|
return fabs(a.distance) > fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot >= b.dot);
|
|
}
|
|
|
|
}
|