Fix artifacts

We were overwriting `end` when clipping, then reusing it when reading
the path, for continuity.
This commit is contained in:
Raph Levien 2020-05-02 16:20:04 -07:00
parent dcdd35e0b8
commit 1797914ac8
2 changed files with 5 additions and 3 deletions

View file

@ -119,6 +119,8 @@ void main() {
&& ytop < ybot && ytop < ybot
&& s00 * s01 + s00 * s10 + s00 * s11 < 3.0) && s00 * s01 + s00 * s10 + s00 * s11 < 3.0)
{ {
// avoid overwriting `end` so that it can be used as start
vec2 enc_end = end;
if (xymin.x < xy0.x) { if (xymin.x < xy0.x) {
float yEdge = mix(start.y, end.y, (start.x - xy0.x) / b); float yEdge = mix(start.y, end.y, (start.x - xy0.x) / b);
if (yEdge >= xy0.y && yEdge < xy1.y) { if (yEdge >= xy0.y && yEdge < xy1.y) {
@ -127,8 +129,8 @@ void main() {
// in piet-metal). // in piet-metal).
FillSegment edge_seg; FillSegment edge_seg;
if (b > 0.0) { if (b > 0.0) {
end = vec2(xy0.x, yEdge); enc_end = vec2(xy0.x, yEdge);
edge_seg.start = end; edge_seg.start = enc_end;
edge_seg.end = vec2(xy0.x, xy1.y); edge_seg.end = vec2(xy0.x, xy1.y);
} else { } else {
start = vec2(xy0.x, yEdge); start = vec2(xy0.x, yEdge);
@ -141,7 +143,7 @@ void main() {
} }
} }
alloc_chunk(chunk_n_segs, seg_chunk_ref, first_seg_chunk, seg_limit); alloc_chunk(chunk_n_segs, seg_chunk_ref, first_seg_chunk, seg_limit);
FillSegment seg = FillSegment(start, end); FillSegment seg = FillSegment(start, enc_end);
FillSegment_write(FillSegmentRef(seg_chunk_ref.offset + FillSegChunk_size + FillSegment_size * chunk_n_segs), seg); FillSegment_write(FillSegmentRef(seg_chunk_ref.offset + FillSegChunk_size + FillSegment_size * chunk_n_segs), seg);
chunk_n_segs++; chunk_n_segs++;
} }

Binary file not shown.