Improve handling of quality value in getWinding()

Relates to #1073
This commit is contained in:
Jürg Lehni 2017-02-04 21:37:05 +01:00
parent bbcfa644d9
commit 0e8b304715

View file

@ -533,38 +533,36 @@ PathItem.inject(new function() {
windingR += winding; windingR += winding;
onPath = true; onPath = true;
} }
} else if (winding !== windingPrev) { // Determine the quality of the winding calculation. Reduce the
// Curve is crossed at starting point and winding changes from // quality with every crossing of the ray very close to the
// previous curve. Cancel the winding from previous curve. // path. This means that if the point is on or near multiple
// curves, the quality becomes less than 0.5.
if (a > pa - qualityEpsilon && a < pa + qualityEpsilon) {
// TODO: Set quality depending on distance
// quality *= Math.min(1, (100 * epsilon * Math.abs(a - pa) + 0.5));
quality /= 2;
}
} else {
if (winding !== windingPrev) {
// Curve is crossed at starting point and winding changes
// from previous curve. Cancel winding from previous curve.
if (a3Prev < paR) { if (a3Prev < paR) {
windingL += winding; windingL += winding;
} } else if (a3Prev > paL) {
if (a3Prev > paL) {
windingR += winding; windingR += winding;
} }
} else if (a3Prev < paL && a > paL || a3Prev > paR && a < paR) { } else if (a3Prev < paL && a > paL || a3Prev > paR && a < paR) {
// Point is on a horizontal curve between the previous non- // Point is on a horizontal curve between the previous non-
// horizontal and the current curve. // horizontal and the current curve.
onPath = true;
if (a3Prev < paL) { if (a3Prev < paL) {
// left winding was added before, now add right winding. // Left winding was added before, now add right winding.
windingR += winding; windingR += winding;
} else if (a3Prev > paR) { } else if (a3Prev > paR) {
// right winding was added before, now add left winding. // Right winding was added before, now add left winding.
windingL += winding; windingL += winding;
} }
onPath = true;
} }
// Determine the quality of the winding calculation. Currently the
// quality is reduced with every crossing of the ray very close
// to the path. This means that if the point is on or near multiple
// curves, the quality becomes less than 0.5
// TODO: Set quality depending on distance
if (po !== o0) {
if (a > pa - qualityEpsilon && a < pa + qualityEpsilon) {
//quality *= Math.min(1, (100 * epsilon * Math.abs(a - pa) + 0.5));
quality /= 2;
}
} else {
// TODO: // TODO:
quality = 0; quality = 0;
} }