From b75def3f3afe0eb252f5364fb41ffb47175343d2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ju=CC=88rg=20Lehni?= Date: Fri, 2 Jan 2015 16:29:12 +0100 Subject: [PATCH 1/2] Implement optimal values in fat line clipping code for maximum recursion and curve time difference, as determined by @iconexperience. Closes #565 --- src/path/Curve.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/path/Curve.js b/src/path/Curve.js index 35d24965..1a038db0 100644 --- a/src/path/Curve.js +++ b/src/path/Curve.js @@ -1056,7 +1056,7 @@ new function() { // Scope for methods that require numerical integration tMin, tMax, uMin, uMax, oldTDiff, reverse, recursion) { /*#*/ if (__options.fatlineClipping) { // Avoid deeper recursion. - if (recursion > 20) + if (recursion > 32) return; // Let P be the first curve and Q be the second var q0x = v2[0], q0y = v2[1], q3x = v2[6], q3y = v2[7], @@ -1107,7 +1107,7 @@ new function() { // Scope for methods that require numerical integration tMaxNew = tMax * tMaxClip + tMin * (1 - tMaxClip); } // Check if we need to subdivide the curves - if (oldTDiff > 0.8 && tDiff > 0.8) { + if (oldTDiff > 0.5 && tDiff > 0.5) { // Subdivide the curve which has converged the least. if (tMaxNew - tMinNew > uMax - uMin) { var parts = Curve.subdivide(v1, 0.5), From e3e3d13fa523ce87202b9dc8992cb01263c1056d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ju=CC=88rg=20Lehni?= Date: Fri, 2 Jan 2015 16:33:15 +0100 Subject: [PATCH 2/2] Add comment regarding issue #565 --- src/path/Curve.js | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/path/Curve.js b/src/path/Curve.js index 1a038db0..76b637d7 100644 --- a/src/path/Curve.js +++ b/src/path/Curve.js @@ -1056,6 +1056,11 @@ new function() { // Scope for methods that require numerical integration tMin, tMax, uMin, uMax, oldTDiff, reverse, recursion) { /*#*/ if (__options.fatlineClipping) { // Avoid deeper recursion. + // NOTE: @iconexperience determined that more than 20 recursions are + // needed sometimes, depending on the tDiff threshold values further + // below when determining which curve converges the least. He also + // recommended a threshold of 0.5 instead of the initial 0.8 + // See: https://github.com/paperjs/paper.js/issues/565 if (recursion > 32) return; // Let P be the first curve and Q be the second