Jürg Lehni
|
1231153553
|
Start cleaning up code from #773
- Use Line object isntead of static methods
- Do not rely on Math.sign() as it's not supported on all browsers
- Wrap lines at 80 char width.
|
2015-09-30 13:07:55 -05:00 |
|
Jürg Lehni
|
2a7d1c5728
|
Improve CurveLocation#equals()
Relates to #784, described in https://github.com/paperjs/paper.js/issues/784#issuecomment-143161586
|
2015-09-30 12:47:02 -05:00 |
|
Jürg Lehni
|
4e9bac1ca5
|
Fix code brokean in commit a869add90d
|
2015-09-30 12:39:59 -05:00 |
|
Jürg Lehni
|
07874034e9
|
Merge pull request #793 from iconexperience/Fix-for-#773
Fix for #773
|
2015-09-30 11:51:37 -05:00 |
|
Jan
|
ec70fa1806
|
Fix for #773
Indroduced more reliable method for finding self intersection on curves.
|
2015-09-30 12:19:09 +02:00 |
|
Jürg Lehni
|
a869add90d
|
Rename variables in Line.intersect()
|
2015-09-26 12:09:44 -05:00 |
|
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 |
|