mirror of https://github.com/Chlumsky/msdfgen.git
82 lines
2.8 KiB
C++
82 lines
2.8 KiB
C++
|
|
#include "Shape.h"
|
|
|
|
namespace msdfgen {
|
|
|
|
Shape::Shape() : inverseYAxis(false) { }
|
|
|
|
void Shape::addContour(const Contour &contour) {
|
|
contours.push_back(contour);
|
|
}
|
|
|
|
#ifdef MSDFGEN_USE_CPP11
|
|
void Shape::addContour(Contour &&contour) {
|
|
contours.push_back((Contour &&) contour);
|
|
}
|
|
#endif
|
|
|
|
Contour & Shape::addContour() {
|
|
contours.resize(contours.size()+1);
|
|
return contours.back();
|
|
}
|
|
|
|
bool Shape::validate() const {
|
|
for (std::vector<Contour>::const_iterator contour = contours.begin(); contour != contours.end(); ++contour) {
|
|
if (!contour->edges.empty()) {
|
|
Point2 corner = contour->edges.back()->point(1);
|
|
for (std::vector<EdgeHolder>::const_iterator edge = contour->edges.begin(); edge != contour->edges.end(); ++edge) {
|
|
if (!*edge)
|
|
return false;
|
|
if ((*edge)->point(0) != corner)
|
|
return false;
|
|
corner = (*edge)->point(1);
|
|
}
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
void Shape::normalize() {
|
|
for (std::vector<Contour>::iterator contour = contours.begin(); contour != contours.end(); ++contour)
|
|
if (contour->edges.size() == 1) {
|
|
EdgeSegment *parts[3] = { };
|
|
contour->edges[0]->splitInThirds(parts[0], parts[1], parts[2]);
|
|
contour->edges.clear();
|
|
contour->edges.push_back(EdgeHolder(parts[0]));
|
|
contour->edges.push_back(EdgeHolder(parts[1]));
|
|
contour->edges.push_back(EdgeHolder(parts[2]));
|
|
}
|
|
}
|
|
|
|
void Shape::bounds(double &l, double &b, double &r, double &t) const {
|
|
for (std::vector<Contour>::const_iterator contour = contours.begin(); contour != contours.end(); ++contour)
|
|
contour->bounds(l, b, r, t);
|
|
}
|
|
|
|
void Shape::miterBounds(double &l, double &b, double &r, double &t, double border, double miterLimit) const {
|
|
for (std::vector<Contour>::const_iterator contour = contours.begin(); contour != contours.end(); ++contour)
|
|
contour->miterBounds(l, b, r, t, border, miterLimit);
|
|
}
|
|
|
|
void Shape::scanline(Scanline &line, double y) const {
|
|
std::vector<Scanline::Intersection> intersections;
|
|
double x[3];
|
|
int dy[3];
|
|
for (std::vector<Contour>::const_iterator contour = contours.begin(); contour != contours.end(); ++contour) {
|
|
for (std::vector<EdgeHolder>::const_iterator edge = contour->edges.begin(); edge != contour->edges.end(); ++edge) {
|
|
int n = (*edge)->scanlineIntersections(x, dy, y);
|
|
for (int i = 0; i < n; ++i) {
|
|
Scanline::Intersection intersection = { x[i], dy[i] };
|
|
intersections.push_back(intersection);
|
|
}
|
|
}
|
|
}
|
|
#ifdef MSDFGEN_USE_CPP11
|
|
line.setIntersections((std::vector<Scanline::Intersection> &&) intersections);
|
|
#else
|
|
line.setIntersections(intersections);
|
|
#endif
|
|
}
|
|
|
|
}
|