blob: 6e3e3de5de4a02f87bb5ef54814bec7b035e4feb [file] [log] [blame]
/*
* Copyright 2021 Google LLC
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef GrInnerFanTriangulator_DEFINED
#define GrInnerFanTriangulator_DEFINED
#include "src/gpu/GrTriangulator.h"
// Triangulates the inner polygon(s) of a path (i.e., the triangle fan for a Redbook rendering
// method). When combined with the outer curves and breadcrumb triangles, these produce a complete
// path. If a breadcrumbCollector is not provided, pathToPolys fails upon self intersection.
class GrInnerFanTriangulator : private GrTriangulator {
public:
using GrTriangulator::BreadcrumbTriangleList;
GrInnerFanTriangulator(const SkPath& path, SkArenaAlloc* alloc)
: GrTriangulator(path, alloc) {
fPreserveCollinearVertices = true;
fCollectBreadcrumbTriangles = true;
}
int pathToTriangles(GrEagerVertexAllocator* vertexAlloc, BreadcrumbTriangleList* breadcrumbList,
bool* isLinear) const {
Poly* polys = this->pathToPolys(breadcrumbList, isLinear);
return this->polysToTriangles(polys, vertexAlloc, breadcrumbList);
}
Poly* pathToPolys(BreadcrumbTriangleList* breadcrumbList, bool* isLinear) const {
Poly* polys = this->GrTriangulator::pathToPolys(0, SkRect::MakeEmpty(), isLinear);
breadcrumbList->concat(std::move(fBreadcrumbList));
return polys;
}
int polysToTriangles(Poly* polys, GrEagerVertexAllocator* vertexAlloc,
BreadcrumbTriangleList* breadcrumbList) const {
int vertexCount = this->GrTriangulator::polysToTriangles(polys, vertexAlloc);
breadcrumbList->concat(std::move(fBreadcrumbList));
return vertexCount;
}
};
#endif