Jürg Lehni
|
317b809fee
|
Only calculate non-parametric bezier curve if values are actually used.
|
2015-09-26 11:46:54 -05:00 |
|
Jürg Lehni
|
ea3cc63e2e
|
Reformat code a bit.
|
2015-09-26 07:41:03 -04:00 |
|
Jan
|
3fa810a557
|
Bugfix for #791 and performance improvement
Prevent infinite loop for degenerate curve. Additionally only calculate sy if necessary and save one call to `Curve.solveCubic`
|
2015-09-26 07:36:12 -04:00 |
|
Jürg Lehni
|
fd927cbe22
|
Properly solve issues with self-intersecting special case.
(e.g. shapes resembling the infinity sign)
|
2015-09-24 12:49:39 -04:00 |
|
Jürg Lehni
|
fc0b5a8858
|
Give the intersection that brings us back to the beginning alwasy the priority.
|
2015-09-24 07:47:39 -04:00 |
|
Jürg Lehni
|
c79166a46f
|
Mark last segment as visited when done.
|
2015-09-23 14:31:12 -04:00 |
|
Jürg Lehni
|
cf5bf38c3b
|
Minor simplification.
|
2015-09-23 13:33:35 -04:00 |
|
Jürg Lehni
|
515d4ff93d
|
Make Line.isCollinear() / Point#isCollinear() more reliable.
|
2015-09-23 13:26:29 -04:00 |
|
Jürg Lehni
|
cc7e60e51a
|
Revert db1ecdddd5 and fix issue properly this time.
Hopefully?
|
2015-09-23 12:44:00 -04:00 |
|
Jürg Lehni
|
20f950ac65
|
Implement #isFirst() / #isLast() tests on Segment and Curve.
|
2015-09-23 12:26:44 -04:00 |
|
Jürg Lehni
|
db1ecdddd5
|
Fix filtering of locations at ends of curves in addCurveLineIntersections()
Only occured when the line / curve had to be flipped.
|
2015-09-21 16:56:08 -04:00 |
|
Jürg Lehni
|
6a29f200e3
|
Always use getIntersection(), even on the first segment.
Now that it works well.
|
2015-09-21 12:44:53 -04:00 |
|
Jürg Lehni
|
51c34444db
|
Some more debugging code clean-up.
|
2015-09-21 12:18:57 -04:00 |
|
Jürg Lehni
|
84bcc537e1
|
Simplify addCurveLineIntersections() and exclude end points.
|
2015-09-21 12:13:53 -04:00 |
|
Jürg Lehni
|
0f61ce896a
|
Some code clean-up.
|
2015-09-21 10:54:33 -04:00 |
|
Jürg Lehni
|
ce95043e99
|
Lower geometric epsilon.
Differences slightly above 1e-8 where observed.
|
2015-09-21 10:54:17 -04:00 |
|
Jürg Lehni
|
812ac63e60
|
Compare points instead of curve time paramters for better precision and reliability.
|
2015-09-21 10:53:53 -04:00 |
|
Jürg Lehni
|
e36319b71a
|
Give PathItem#getIntersections() a way to filter found intersections right away.
And use it in #getCrossings()
|
2015-09-21 10:41:59 -04:00 |
|
Jürg Lehni
|
f6f42fe09b
|
Improve handling of overlap ambiguity in getIntersection()
Two passes are needed, first strict, then non-strict, to prevent 'better' next candiates over 'worse' ones.
|
2015-09-21 09:44:17 -04:00 |
|
Jürg Lehni
|
19a17b2918
|
Prevent infinite loops through circular references of multiple intersections.
|
2015-09-21 09:43:19 -04:00 |
|
Jürg Lehni
|
40570b3e59
|
Furher improve boolean debug logging and drawing.
|
2015-09-21 09:42:47 -04:00 |
|
Jürg Lehni
|
1ad95c9020
|
Improve CurveLocation.add() to always merge duplicates.
We nee to check neighbors of the found location too.
|
2015-09-21 07:06:41 -04:00 |
|
Jürg Lehni
|
f47af12b0d
|
Shorten code statement.
|
2015-09-20 23:22:41 +02:00 |
|
Jürg Lehni
|
1302df0cb8
|
Fix variable leackage.
|
2015-09-20 23:22:31 +02:00 |
|
Jürg Lehni
|
b68be09c87
|
Fix all accidental non-breaking spaces.
|
2015-09-20 22:39:28 +02:00 |
|
Jürg Lehni
|
530b8b7bc8
|
Handle adjusted overlap winding contribution and operator calls through new isValid() function.
|
2015-09-20 15:50:26 +02:00 |
|
Jürg Lehni
|
738cc4c214
|
Yet another improvement in multiple interseections boolean code.
This appears to be the one. The only remaining failing cases seem to be linked to getting the same intersection twice now!
Relates to #787
|
2015-09-20 15:29:54 +02:00 |
|
Jürg Lehni
|
946157f1b1
|
Add note about usage of _originalWinding.
|
2015-09-20 14:19:14 +02:00 |
|
Jürg Lehni
|
20ed1e007c
|
More fixes in handling of multiple intersection locations.
|
2015-09-20 14:17:23 +02:00 |
|
Jürg Lehni
|
5db9703aff
|
No more need to check for crossings since every intersection is now either an overlap or a crossing.
|
2015-09-20 14:16:47 +02:00 |
|
Jürg Lehni
|
53862233e5
|
Improve debug logging of new multiple intersections code.
|
2015-09-19 22:47:57 +02:00 |
|
Jürg Lehni
|
4df65c1809
|
Various improvements to code that handles multiple intersections in same location.
Relates to #787
|
2015-09-19 19:07:44 +02:00 |
|
Jürg Lehni
|
1d6f552212
|
Prevent endless loop through circular references.
|
2015-09-19 13:42:48 +02:00 |
|
Jürg Lehni
|
2c8634793c
|
First attempt at implementing handling of multiple intersections in the same location.
Relates to #787, works pretty well already for many situations.
|
2015-09-19 13:21:29 +02:00 |
|
Jürg Lehni
|
18c5a06f45
|
Fix colors in animated boolean operations demo.
|
2015-09-18 23:00:47 +02:00 |
|
Jürg Lehni
|
081de1d12a
|
'exclude' operation needs overlap handling too.
|
2015-09-18 22:29:29 +02:00 |
|
Jürg Lehni
|
a95ba12bc3
|
isCrossing() needs parameter checks on both curves.
|
2015-09-18 22:26:09 +02:00 |
|
Jürg Lehni
|
b5af47a7b1
|
Implement a better approach to calculate Path#clockwise...
...merging code with Path#area.
Closes #788
|
2015-09-18 21:41:54 +02:00 |
|
Jürg Lehni
|
8cf562c57b
|
Revert "Remove special handling of winding contribution on overlaps"
This reverts commit c6a38589e9 .
The special handling seems to be still necessary in some edge cases, e.g. in BooleanOperations.html
|
2015-09-18 21:10:58 +02:00 |
|
Jürg Lehni
|
10eafccd1a
|
Implement 0.75 * handle scaling in curve bounds checks.
|
2015-09-18 21:09:57 +02:00 |
|
Jürg Lehni
|
17dc5eb51a
|
Allow gettings of unstyled bounds on curves without paths.
|
2015-09-18 20:15:18 +02:00 |
|
Jürg Lehni
|
c6a38589e9
|
Remove special handling of winding contribution on overlaps
Looks like the new code handles this correclty now!
|
2015-09-18 18:06:15 +02:00 |
|
Jürg Lehni
|
5af391d333
|
Fix errors in Boolean Operations example.
|
2015-09-18 17:52:14 +02:00 |
|
Jürg Lehni
|
23443dc8f4
|
Clean up boolean code.
|
2015-09-18 17:51:57 +02:00 |
|
Jürg Lehni
|
66b01973f0
|
Simplify exclusion handling for new boolean code.
|
2015-09-18 17:51:43 +02:00 |
|
Jürg Lehni
|
87687d816b
|
Implement PathItem#resolveCrossings() based on the new #getCrossings() method.
|
2015-09-18 17:51:03 +02:00 |
|
Jürg Lehni
|
c70f8cb3cc
|
Simplify overlap calculations by keeping the original winding value.
|
2015-09-18 17:46:46 +02:00 |
|
Jürg Lehni
|
59a23fdd3f
|
Improve debug logging.
|
2015-09-18 17:33:42 +02:00 |
|
Jürg Lehni
|
73a9989261
|
Fix CurveLocation#isCrossing() for locations in the middle of curves.
|
2015-09-18 17:32:19 +02:00 |
|
Jürg Lehni
|
ae93652b56
|
Clean up getIntersection() methods.
Now that they filter the results on the fly.
|
2015-09-18 17:31:23 +02:00 |
|