GrTessellator: collinear edges during sanitize.
When three collinear edges occur during the sanitize_contours() pass, their vertices may not yet have been discovered to be coincident. So we must do the vertex comparison by point, rather than by pointer. Bug: 860655 Change-Id: I89dc7526905bb5473206661348fee431371731a0 Reviewed-on: https://skia-review.googlesource.com/141523 Reviewed-by: Robert Phillips <robertphillips@google.com> Commit-Queue: Stephen White <senorblanco@chromium.org>
This commit is contained in:
parent
b983e6baa1
commit
71ed661963
@ -1053,16 +1053,18 @@ void merge_edges_below(Edge* edge, Edge* other, EdgeList* activeEdges, Vertex**
|
|||||||
|
|
||||||
void merge_collinear_edges(Edge* edge, EdgeList* activeEdges, Vertex** current, Comparator& c) {
|
void merge_collinear_edges(Edge* edge, EdgeList* activeEdges, Vertex** current, Comparator& c) {
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (edge->fPrevEdgeAbove && (edge->fTop == edge->fPrevEdgeAbove->fTop ||
|
const SkPoint& top = edge->fTop->fPoint;
|
||||||
|
const SkPoint& bottom = edge->fBottom->fPoint;
|
||||||
|
if (edge->fPrevEdgeAbove && (edge->fPrevEdgeAbove->fTop->fPoint == top ||
|
||||||
!edge->fPrevEdgeAbove->isLeftOf(edge->fTop))) {
|
!edge->fPrevEdgeAbove->isLeftOf(edge->fTop))) {
|
||||||
merge_edges_above(edge->fPrevEdgeAbove, edge, activeEdges, current, c);
|
merge_edges_above(edge->fPrevEdgeAbove, edge, activeEdges, current, c);
|
||||||
} else if (edge->fNextEdgeAbove && (edge->fTop == edge->fNextEdgeAbove->fTop ||
|
} else if (edge->fNextEdgeAbove && (edge->fNextEdgeAbove->fTop->fPoint == top ||
|
||||||
!edge->isLeftOf(edge->fNextEdgeAbove->fTop))) {
|
!edge->isLeftOf(edge->fNextEdgeAbove->fTop))) {
|
||||||
merge_edges_above(edge->fNextEdgeAbove, edge, activeEdges, current, c);
|
merge_edges_above(edge->fNextEdgeAbove, edge, activeEdges, current, c);
|
||||||
} else if (edge->fPrevEdgeBelow && (edge->fBottom == edge->fPrevEdgeBelow->fBottom ||
|
} else if (edge->fPrevEdgeBelow && (edge->fPrevEdgeBelow->fBottom->fPoint == bottom ||
|
||||||
!edge->fPrevEdgeBelow->isLeftOf(edge->fBottom))) {
|
!edge->fPrevEdgeBelow->isLeftOf(edge->fBottom))) {
|
||||||
merge_edges_below(edge->fPrevEdgeBelow, edge, activeEdges, current, c);
|
merge_edges_below(edge->fPrevEdgeBelow, edge, activeEdges, current, c);
|
||||||
} else if (edge->fNextEdgeBelow && (edge->fBottom == edge->fNextEdgeBelow->fBottom ||
|
} else if (edge->fNextEdgeBelow && (edge->fNextEdgeBelow->fBottom->fPoint == bottom ||
|
||||||
!edge->isLeftOf(edge->fNextEdgeBelow->fBottom))) {
|
!edge->isLeftOf(edge->fNextEdgeBelow->fBottom))) {
|
||||||
merge_edges_below(edge->fNextEdgeBelow, edge, activeEdges, current, c);
|
merge_edges_below(edge->fNextEdgeBelow, edge, activeEdges, current, c);
|
||||||
} else {
|
} else {
|
||||||
|
@ -600,6 +600,22 @@ static SkPath create_path_41() {
|
|||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Reduction from crbug.com/860655. Cause is three collinear edges discovered during
|
||||||
|
// sanitize_contours pass, before the vertices have been found coincident.
|
||||||
|
static SkPath create_path_42() {
|
||||||
|
SkPath path;
|
||||||
|
path.moveTo( 32572426382475264, -3053391034974208);
|
||||||
|
path.lineTo( 521289856, -48865776);
|
||||||
|
path.lineTo( 130322464, -12215873);
|
||||||
|
path.moveTo( 32572426382475264, -3053391034974208);
|
||||||
|
path.lineTo( 521289856, -48865776);
|
||||||
|
path.lineTo( 130322464, -12215873);
|
||||||
|
path.moveTo( 32572426382475264, -3053391034974208);
|
||||||
|
path.lineTo( 32114477642022912, -3010462031544320);
|
||||||
|
path.lineTo( 32111784697528320, -3010209702215680);
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
static std::unique_ptr<GrFragmentProcessor> create_linear_gradient_processor(GrContext* ctx) {
|
static std::unique_ptr<GrFragmentProcessor> create_linear_gradient_processor(GrContext* ctx) {
|
||||||
|
|
||||||
SkPoint pts[2] = { {0, 0}, {1, 1} };
|
SkPoint pts[2] = { {0, 0}, {1, 1} };
|
||||||
@ -701,4 +717,5 @@ DEF_GPUTEST_FOR_ALL_CONTEXTS(TessellatingPathRendererTests, reporter, ctxInfo) {
|
|||||||
test_path(ctx, rtc.get(), create_path_39());
|
test_path(ctx, rtc.get(), create_path_39());
|
||||||
test_path(ctx, rtc.get(), create_path_40());
|
test_path(ctx, rtc.get(), create_path_40());
|
||||||
test_path(ctx, rtc.get(), create_path_41(), SkMatrix(), GrAAType::kCoverage);
|
test_path(ctx, rtc.get(), create_path_41(), SkMatrix(), GrAAType::kCoverage);
|
||||||
|
test_path(ctx, rtc.get(), create_path_42());
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user