1234567891011121314151617181920212223242526272829303132333435363738 |
- #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);
- }
- }
|