Jürg Lehni
cb3d4341fd
paper.browser can still be null when the first key events fire.
2016-01-08 11:42:12 +01:00
Jürg Lehni
79508ff78b
Various comments adjustments.
2016-01-08 11:14:25 +01:00
Jürg Lehni
abafc886cd
Clean up propagateWinding() a bit.
2016-01-08 10:54:11 +01:00
Jürg Lehni
34a173ee18
Merge pull request #893 from sapics/atan2
...
Replace atan to atan2 for avoiding NaN
2016-01-08 10:28:44 +01:00
Jürg Lehni
b95136f673
Add additional @author tags to boolean code.
2016-01-08 10:27:22 +01:00
Jürg Lehni
a5304443a5
Condensate if / else statements into terniary chain.
...
And apply the same style to all multi-line if-statements.
2016-01-08 10:22:11 +01:00
Jürg Lehni
d186c2d356
Reformat code of #895 a bit.
...
- Respect 80 chars line-width
- Indent comments with current indentation level
- Use punctuation in comments
2016-01-08 10:05:47 +01:00
iconexperience
07b89c7f18
Further simplify and explain winding calculation in getWinding()
2016-01-08 08:58:32 +01:00
sapics
5f876adc1c
Replace atan to atan2 for avoiding NaN
2016-01-08 12:24:53 +09:00
Jürg Lehni
3c66c013d1
Implement correct behavior for intersection, subtraction and intersection of fully overlapping paths.
2016-01-08 01:25:35 +01:00
Jürg Lehni
ba6c1201fe
Improve a couple of comments.
2016-01-08 01:09:15 +01:00
Jürg Lehni
eba9601601
Implement and brush up @iconexperience's new version of getWinding()
...
Along with optimizations and simplifications to _getMonoCurves()
Closes #890
2016-01-08 00:08:38 +01:00
Jürg Lehni
6136bd8143
Fix issue with SVG serialization in newer versions of JSDOM.
...
And define some meaningful ranges for problematic Node.js modules.
Closes #821
2016-01-07 23:08:01 +01:00
Jürg Lehni
56869baaad
Only transform canvas if matrix is not the identity.
2016-01-07 22:07:26 +01:00
Jürg Lehni
7969e4647c
Use shadowBlur instead of shadowColor to clear shadows after fills.
2016-01-07 22:06:10 +01:00
Jürg Lehni
d1e4807c6a
Allow the use of Formater without additional processing of numbers.
...
precision >= 16 will output numbers as is.
2016-01-07 18:51:30 +01:00
Jürg Lehni
36a98706b3
Use epsilons when deciding for horizontal winding and dealing with horizontal mono-curves.
...
Relates to #890#issuecomment-169672571, fixing the 2nd case of the 2nd example.
2016-01-07 15:58:51 +01:00
Jürg Lehni
bc8fb92b9d
Rename some variables to be more clear about their role.
2016-01-07 15:55:24 +01:00
Jürg Lehni
5e01774c91
Further simplify checks of crossing vs touching in getWinding()
...
Relates to #890
2016-01-07 13:09:47 +01:00
Jürg Lehni
231dba83b2
No need to filter intersections if there were no overlaps.
2016-01-07 12:15:11 +01:00
Jürg Lehni
86b9d04c43
Rename from, to parameters to start, end in methods where the end is exclusive.
...
Relates to #338
2016-01-07 11:29:36 +01:00
Jürg Lehni
af797df5ba
Remove includeOverlaps parameter from getCrossings()
...
And write better comments about how overlaps should be dealt with ideally.
2016-01-07 11:18:46 +01:00
Jürg Lehni
2fc7684efb
Optimize new getWinding() code a bit.
...
By storing additional information along the first curve of a monoCurve loop.
2016-01-07 11:02:51 +01:00
Jürg Lehni
1078e1f8a9
Implement winding fix suggested by @iconexperience.
...
Along with a unit test for the issue.
Closes #890
2016-01-07 10:02:43 +01:00
Jürg Lehni
e5a62cb919
Fix new failing tests in @iconexperience's test suite.
...
Relates to comments on 5a16d0cd01
2016-01-07 09:50:07 +01:00
Jürg Lehni
7ad6dc2d5f
Add support for Curve objects in smooth() ranges.
2016-01-06 22:37:51 +01:00
Jürg Lehni
5f11345fc9
Implement from / to options for 'continuous' smooth().
2016-01-06 22:31:02 +01:00
Jürg Lehni
71c7405d6b
Some work on documentation structure for #smooth().
2016-01-06 17:16:04 +01:00
Jürg Lehni
bf4eb47fae
Start implementing new smooth() functions that merge all approaches.
...
Work in progress, needs more work on range handling for 'continous', and docs.
2016-01-06 16:11:19 +01:00
Jürg Lehni
2539527864
Fix minification warnings.
2016-01-06 15:25:37 +01:00
Jürg Lehni
8cec4f972d
Handle tiny handles correctly In Curve's evaluate()
...
If the curve handles are almost zero, reset the control points to the anchors.
Closes #838
2016-01-06 15:03:35 +01:00
Jürg Lehni
b9c76f44e8
Convert "Note: " comments to "NOTE: " and do some cleanup.
2016-01-06 14:23:19 +01:00
Jürg Lehni
7152942719
Replace links to issues with short references.
2016-01-06 14:13:02 +01:00
Jürg Lehni
156dd661ed
Detect and handle fully overlapping paths in boolean operations.
...
Closes #885
2016-01-06 11:54:23 +01:00
Jürg Lehni
feec904288
Fix white-space.
2016-01-06 11:14:38 +01:00
Jürg Lehni
df580425f4
Remove sameDir parameter from isCollinear() agian.
...
It's not in use anywhere now.
2016-01-06 11:08:17 +01:00
Jürg Lehni
5a16d0cd01
Implement proper handling of self-touching paths in resolveCrossings().
...
Closes #874 , #887
2016-01-06 10:53:50 +01:00
Jürg Lehni
d89995a781
Fix winding calculation in rare edge case.
...
Closes #889
2016-01-06 00:34:23 +01:00
Jürg Lehni
17d000266f
Deactivate use of sameDir in Path#reduce() for now.
2016-01-06 00:27:11 +01:00
Jürg Lehni
cb6afda083
Add sameDir parameter it #isCollinear() functions and use it in Path#reduce().
2016-01-05 14:51:55 +01:00
Jürg Lehni
0a7bb06d93
Implement suggestions by @iconexperience in #887
2016-01-05 12:43:38 +01:00
Jürg Lehni
928ad48937
Rename start/endConnected to excludeStart/End.
2016-01-05 12:14:21 +01:00
Jürg Lehni
a7fc04a9b1
Improve comments in new getOverlaps() code.
2016-01-05 12:11:56 +01:00
Jürg Lehni
0d172a74f4
Start handling self-overlapping paths in getOverlaps()
...
Relates to #874 and #887
2016-01-05 12:04:40 +01:00
Jürg Lehni
d71acb4002
Further simplify boolean operator handling.
2016-01-05 11:10:59 +01:00
Jürg Lehni
1132de0415
Clean up boolean code comments a bit.
2016-01-05 11:06:06 +01:00
Jürg Lehni
4a10fe33d3
Refactor and improve handling of boolean operators.
...
Also detect a case where all encountered segments are part of overlaps, and add parameter startInOverlaps that handles this situation.
Closes #870
2016-01-05 10:30:33 +01:00
Jürg Lehni
bcf000788e
Reduce GEOMETRIC_EPSILON again.
...
Reverting daaf625ebd
2016-01-04 12:53:30 +01:00
Jürg Lehni
34d4115061
Do not modify children array directly
...
Use Item#remove() to remove children, to make sure indices are kept in sync.
2016-01-04 11:12:56 +01:00
Jürg Lehni
1543d056a7
Add more boolean unit tests from known edge cases.
2016-01-04 11:01:42 +01:00
Jürg Lehni
9127b13a01
Use GEOMETRIC_EPSILON tolerance when filtering out short curves.
...
Aligning with tolerances in the rest of the library.
2016-01-04 10:38:51 +01:00
Jürg Lehni
daaf625ebd
Double GEOMETRIC_EPSILON to cover the last found edge case.
...
See https://github.com/paperjs/paper.js/issues/784#issuecomment-168614053
2016-01-04 10:02:58 +01:00
Jürg Lehni
88634d4d3d
The paper.browser object might not be initialized yet.
2016-01-03 01:23:17 +01:00
Jürg Lehni
26761f17a1
Some minor clean-ups for 55cf0bc1c7
.
2016-01-03 01:13:03 +01:00
Jürg Lehni
55cf0bc1c7
Improve and simplify handling of start segments.
...
Removing findStartSegment() and merging functionality into findBestIntersection() leads to simpler code and solves some remaining issue, e.g. https://github.com/paperjs/paper.js/issues/784#issuecomment-153282113
2016-01-03 01:08:11 +01:00
Jürg Lehni
9404c5a0e3
Restructure code from #883 a bit
...
- Use === instead of == for strict numeric comparisons
- Merge the two return statements to one
- Address some imprecisions in previously added comments
2016-01-02 23:39:13 +01:00
iconexperience
ebaccf6e2d
Add break condition for exactly collinear curves to prevent a very time consuming clipping process that cannot have a result.
2016-01-02 19:08:42 +01:00
Jürg Lehni
957d303a0d
Make sure the key identifier is always lowercase.
...
Relates to #881
2016-01-02 13:58:05 +01:00
Jürg Lehni
afffdfdddd
Clean up comments a little.
2016-01-02 13:20:36 +01:00
Jürg Lehni
df09e14d53
Address keyIdentifier weirdness in Chrome on Ubuntu.
...
Closes #881
2016-01-02 13:17:24 +01:00
Jürg Lehni
ce1f04d76c
Remove reliance on downKey, since it may differ between keydown and keypress events.
...
Relates to #881 , but unfortunately does not fix it.
2016-01-02 13:02:20 +01:00
Jürg Lehni
3234975e46
Include comment about methods produced on the fly.
...
For easier searching.
2015-12-31 18:32:56 +01:00
Jürg Lehni
fa15b083b0
Go back to matching curve beginnings / ends with GEOMETRIC_EPSILON.
...
This is possible because we're handling the special line case separately before already.
2015-12-31 14:23:16 +01:00
Jürg Lehni
f8791f2be5
Perform bounding box checkes with GEOMETRIC_EPSILON
...
Closes #878
2015-12-31 10:21:38 +01:00
sapics
3f50aadf3b
Fix comment of rectangle.expand
2015-12-31 13:04:00 +09:00
Jürg Lehni
df24de0fdf
Optimize fat-line clipping code a bit further.
...
We don't need to calculate v1Clip and tDiff if oldTDiff > 0.5 && tDiff > 0.5.
2015-12-30 23:19:58 +01:00
Jürg Lehni
f19bdf9834
Remove unrequired testContains parameter.
2015-12-30 21:55:22 +01:00
Jürg Lehni
92904e95c2
Address proposal by @iconexperience in #869 and shorten code.
...
Closes #877
2015-12-30 21:55:22 +01:00
Jürg Lehni
511fc12dd4
Implement more special key lookups in new Key handling code.
...
Relates to #876 .
2015-12-30 21:55:22 +01:00
Jürg Lehni
943c4bba91
Improve horizontal check for sampling points in propagateWinding()
...
Relates to #875 , needs more testing.
2015-12-30 21:55:21 +01:00
Jürg Lehni
a1fcaabed6
Implement item comparison through rasterization and resemble.js diffing, directly integrated into QUnit.
...
And start using it for boolean operation unit tests.
2015-12-30 21:55:21 +01:00
Jürg Lehni
2596b81616
Add optional insert
parameter to #rasterize()
2015-12-30 21:55:21 +01:00
Jürg Lehni
62a23662fa
Unify handling of insert
parameters.
2015-12-30 21:55:21 +01:00
Jürg Lehni
44f98ee094
Replace all mention of DOM in the documentation with scene graph.
2015-12-30 21:55:21 +01:00
Jürg Lehni
c0a2e0ec63
Support insert parameter again in #toShape() / #toPath()
2015-12-30 21:55:21 +01:00
Jürg Lehni
060ab5e7f9
Only mark overlap segments as visited during #intersect().
2015-12-30 21:55:21 +01:00
Jürg Lehni
f4f46fa985
Implement optimization suggested by @iconexperience in #869
2015-12-30 21:55:20 +01:00
Jürg Lehni
0e427c16a2
Fix some white-spaces in comments and HTML.
2015-12-30 21:55:20 +01:00
Jürg Lehni
bf65866b58
Port over boolean #intersect() fix from c6b1a8067f5045e94294735a21aa2fa222fbb2a1
...
Relates to #870
2015-12-30 21:55:20 +01:00
Jürg Lehni
fa9698aaaa
Revert back to always call #setClockwise() in #resolveCrossings()
...
This solves some regressions, e.g. https://github.com/paperjs/paper.js/issues/869#issuecomment-167586249
2015-12-30 21:55:20 +01:00
Jürg Lehni
4d13f0e1e0
Simple optimization in PathItem#contains()
...
Perform a handle bounds check before calculating winding, as described by @iconexperience in #869
2015-12-30 21:55:20 +01:00
Jürg Lehni
5c976420f8
Further improve #resolveCrossings() based on discussion with @iconexperience.
...
Closes #869
2015-12-30 21:55:20 +01:00
Jürg Lehni
d6a8538674
Fix overlap handling for boolean intersection.
...
Closes #870
2015-12-30 21:55:20 +01:00
Jürg Lehni
b5a38ae5ec
Fix orientation handling in new #resolveCrossings().
...
Closes #869
2015-12-30 21:55:20 +01:00
Jürg Lehni
85f08825d7
Implement support for CSS blend-modes in SVGExport.
2015-12-30 21:55:20 +01:00
Jürg Lehni
ecad1c6a0d
More code clean-ups and simplifications for #852
2015-12-30 21:55:20 +01:00
Jürg Lehni
973491f962
Some code-clean up for #852
...
Mainly to make it fit into the 80 char line lenght.
2015-12-30 21:55:20 +01:00
Jürg Lehni
f34afbc19a
Clean up code from #856 a bit.
2015-12-30 21:55:19 +01:00
Jürg Lehni
d67796f655
Some more documentation work.
2015-12-30 21:55:19 +01:00
Jürg Lehni
8967193bb9
Improve SVG definition id parsing.
...
Closes #666
2015-12-30 21:55:19 +01:00
Jürg Lehni
cc1e58e243
Improve Chrome fix to handle wrong coordinates in both directions.
...
Closes #800 .
2015-12-30 21:55:19 +01:00
Jürg Lehni
21f4141e4f
Fix werid mouse event issue on Chrome / Windows.
...
Closes #800
2015-12-30 21:55:19 +01:00
Jürg Lehni
32cf1ba69e
Partly revert "Treat overlaps as crossings as well."
...
This partly reverts commit deafacdad0
and closes #868
2015-12-30 21:55:19 +01:00
Jürg Lehni
a7a07fb6d5
Update JSDoc and do some documentation spring-cleaning.
...
- Convert from {@code ...} to shorter `...`
- Reformat some documentation comment blocks
- Update copyright notices
2015-12-30 21:55:19 +01:00
Jürg Lehni
7d25096de6
Fix new failing #isCrossing() test-case.
2015-12-30 21:55:19 +01:00
Jürg Lehni
a20b0469d6
Correctly keep track of all straight curves that need their handles cleared at the end.
...
Closes #838
2015-12-30 21:55:19 +01:00
Jürg Lehni
b724a59901
Handle non-reversible matrix in Item#hitTest()
...
Closes #617
2015-12-30 21:55:18 +01:00
Jürg Lehni
f2f34c3b75
Some minor fixes in new #getItems() code.
2015-12-30 21:55:18 +01:00
Jürg Lehni
f2a44a5832
Remove Base#class again as it's causing issues in lookup tables.
2015-12-30 21:55:18 +01:00
Jürg Lehni
de532aac2f
Implement control over recursive iteration in #getItems()
...
Closes #853 .
2015-12-30 21:55:18 +01:00
Jürg Lehni
f95d6ab310
Fix bug in Item#getItems(function() {})
...
Closes #751
2015-12-30 21:55:18 +01:00
Jürg Lehni
08d75a48ff
Fix issue again with param.overlapping in #getItems()
...
This time, properly!
Closes #751
2015-12-30 21:55:18 +01:00
Jürg Lehni
93a5e2d18c
Refine some code comments.
2015-12-30 21:55:18 +01:00
Jürg Lehni
aa316ffc8c
Avoid applying item._matrix twice in Item#intersects()
...
As suggested by @sapics.
Closes #847
2015-12-30 21:55:18 +01:00
Jürg Lehni
7592895445
Big overhaul of CurveLocation#isCrossing()
...
Improved to better handle touching curves and edge cases involving straight curves.
Closes #865
2015-12-30 21:55:18 +01:00
Jürg Lehni
306d8bae86
Clean up the new Item#reduce() code a bit.
2015-12-30 21:55:18 +01:00
Jürg Lehni
fec67617e1
Merge pull request #846 from iconexperience/reduce-fix
...
Make sure reduced item has no parent if original item had no parent.
Fix for #835
2015-12-30 21:55:18 +01:00
Jürg Lehni
b987590c71
Define documentation for excludeMatrix parameter.
2015-12-30 21:55:18 +01:00
Jürg Lehni
83b53cb9e0
Fix a few edge cases in cloning and copying of attributes.
2015-12-30 21:55:17 +01:00
Jürg Lehni
2fea40f86f
Introduce new Item#copyAttributes() & #copyContent(), and revamp #clone() handling.
2015-12-30 21:55:17 +01:00
Jürg Lehni
463f50a0c1
Adjust comment by @iconexperience.
...
As outlined here: https://github.com/paperjs/paper.js/issues/854#issuecomment-167334294
2015-12-30 21:55:17 +01:00
Jürg Lehni
386632b0be
Implement new version of #reorient() and merge with #resolveCrossings()
...
As proposed by @iconexperience in #854
2015-12-30 21:55:17 +01:00
Jürg Lehni
48c0988546
Implement support for SVG fill-rule attribute.
...
Relates to #858
2015-12-30 21:55:17 +01:00
Jürg Lehni
a5f05c90f5
Rename #windingRule to #fillRule.
...
...keeping deprecated aliases on Style and Item around for now.
Closes #858
2015-12-30 21:55:17 +01:00
Jürg Lehni
086485dc95
Minor code clean-up.
2015-12-30 21:55:17 +01:00
Jürg Lehni
401877c6dc
Fix the correct bubbling of doubleclick events.
...
Fixes #834 .
2015-12-30 21:55:17 +01:00
Jürg Lehni
e3a27da7b2
Fix alt key combos on Chrome.
...
Relates to #860
2015-12-30 21:55:17 +01:00
Jürg Lehni
0badb3b3f4
A bunch of code clean-ups.
2015-12-30 21:55:16 +01:00
Jürg Lehni
248364aebc
Fix @param description.
2015-12-30 21:55:16 +01:00
Jürg Lehni
4ee3a76a74
Improve handling of special characters and control sequences.
2015-12-30 21:55:16 +01:00
Jürg Lehni
0346552bc6
Minor simplification.
2015-12-30 21:55:16 +01:00
Jürg Lehni
52edd72efb
Refactor Key handling
...
- Rely on event.key / event.keyIdnetifier instead of event.keyCode
- Handle command key better on Chrome across all platforms (fixes #860 )
- Improve documentation
2015-12-30 21:55:16 +01:00
iconexperience
b19bc5aaf4
Smaller improvements in addCurveIntersections()
2015-12-30 21:55:16 +01:00
sapics
81a4d142f0
Fix shape.strokeBounds with strokeScaling is false
2015-12-30 21:52:34 +01:00
iconexperience
0e3ac9d7f4
Handle cases when point y is equal to y of horizontal curve in path
2015-12-30 21:52:34 +01:00
sapics
9c1c00c11e
Minor minification
2015-12-30 21:52:34 +01:00
sapics
0050984d83
Remove unnecessary calculation
2015-12-30 21:52:34 +01:00
iconexperience
c0a5739254
Change addCurveIntersections() to handle cases when tDiff == 0
2015-12-19 10:48:31 +01:00
Jürg Lehni
1e72447a7d
Minor comment change.
2015-11-12 10:12:46 +01:00
Jürg Lehni
8149fa830b
Only rasterize an item's content if the resulting raster is not empty.
...
closes #828
2015-11-12 10:11:31 +01:00
Jürg Lehni
deafacdad0
Treat overlaps as crossings as well.
...
This solves https://github.com/paperjs/paper.js/issues/784#issuecomment-153085486 , simplifies code quite a bit, and does not cause any new issues.
2015-11-04 01:19:20 +01:00
Jürg Lehni
f32a1def6e
Only complain about open paths in boolean ops when they are long enough.
2015-11-02 18:21:19 +01:00
Jürg Lehni
9a772678a8
Clean up #816 a bit.
...
Closes #815 also.
2015-10-28 22:17:44 +01:00
Tomas Junnonen
09d4de6a1b
Issue 815: Cannot add segment to Path after removing last segment
...
Fixed an issue where after removing the last segment of a path,
new segments cannot be re-added.
Added new Path Curve test cases to test the difference between
a path with one and no segments (zero curves in both cases), which
catches the bug.
2015-10-28 12:15:07 -04:00
Jürg Lehni
6c0faaf010
Use Base.pick() instead of null check.
2015-10-27 23:43:14 +01:00
Jürg Lehni
60c64ab25c
Merge pull request #814 from johan/precision-0
...
Handle exportSVG({ precision: 0 }) correctly
2015-10-27 23:41:55 +01:00
Jürg Lehni
8eb0dcc87d
Fix various JS linting problems.
2015-10-27 23:35:30 +01:00
Johan Sundström
1b129feebf
Handle exportSVG({ precision: 0 }) correctly
2015-10-27 15:33:09 -07:00
Jürg Lehni
ac7c272401
Clean up link references about kappa.
2015-10-26 21:43:38 +01:00
Jürg Lehni
a1e4b9fa3c
Release version v0.9.25
2015-10-25 11:24:42 +01:00
Jürg Lehni
238801e485
Improve docs for boolean operations.
2015-10-25 09:41:43 +01:00
Jürg Lehni
e9d54a05f0
Minor change in the way #reorient() is called.
2015-10-24 23:13:13 +02:00
Jürg Lehni
c61cb804cb
Implement boolean operations intersect() and subtract() for open path with closed paths.
...
Closes #757
2015-10-24 22:41:51 +02:00
Jürg Lehni
648985fcd2
Fix yet another issue with Path#curves and Path#_add()
...
Including a unit test to prevent regression.
2015-10-24 18:11:30 +02:00
Jürg Lehni
19e3136892
Address small issue in Path#getLocationAt() when paths are empty.
2015-10-24 17:46:20 +02:00
Jürg Lehni
fcd4fe824c
Pass Item.NO_INSERT to internally created paths and do not rely on insertAbove() to always return a result.
...
If `this` itself is not in the DOM, insertAbove() will fail.
2015-10-24 17:45:22 +02:00
Jürg Lehni
1fc17766fb
Address remaining issue with curves being wrongly linked up after adding new segments.
2015-10-24 17:43:22 +02:00
Jürg Lehni
ae2bed9cf0
Fix issue of faulty curves list after inserting segments at the end of open paths.
2015-10-24 17:00:37 +02:00
Jürg Lehni
39731808b8
Switch from imprecise trigonometric method to Curve.getParameterOf()
...
And from !hasHandles() to isStraight(), as we can now handle all straight curves.
2015-10-24 12:23:25 +02:00
Jürg Lehni
780b999220
Fix typo.
2015-10-24 11:55:59 +02:00
Jürg Lehni
b9a0f5f659
Further simplify code.
2015-10-24 11:29:15 +02:00
Jürg Lehni
4678697638
Some refactoring and added comments to @sapics code in Curve.getNearestParameter()
2015-10-24 11:14:08 +02:00
sapics
89a45a6682
Use cubic equation solution for faster calculation
2015-10-24 14:54:57 +09:00
sapics
294904eac7
Faster curve.getNearestParameter when curve has no handles
2015-10-24 11:39:50 +09:00
Jürg Lehni
c8cc653004
Merge Path#_getOffset() with CurveLocation#getOffset()
2015-10-23 19:57:25 +02:00
sapics
502558a321
Fix variable leaks
2015-10-23 09:45:39 +09:00
Jürg Lehni
5be9e1dde5
Remove unused variable.
2015-10-22 15:30:29 +02:00
Jürg Lehni
813ea48932
Remove unused local reference.
2015-10-22 14:46:17 +02:00
Jürg Lehni
85f7134fe6
Reduce curve-time epsilon, and improve comments about other epsilon values.
2015-10-22 10:34:49 +02:00
Jürg Lehni
bafb6794a6
Introduce separate epsilon for fat-line clipping code, and reduce curve-time epsilon.
2015-10-21 23:44:24 +02:00
Jürg Lehni
e9c3e72f60
Simplify handling of winding overlap-adjustment in isValid()
2015-10-21 15:02:53 +02:00
Jürg Lehni
a79212b920
Make handling of points on infinite lines in Line.getSide() more clear.
2015-10-21 10:00:11 +02:00
Jürg Lehni
a9710cf7c0
Fix Line.getSide() call.
2015-10-21 09:35:55 +02:00
Jürg Lehni
0cb792de93
Reverse sign of Line.getSignedDistance()
...
Closes #789
2015-10-21 09:35:40 +02:00
Jürg Lehni
7c37a4a4d2
Revert "No need for special length handling in propagateWinding()"
...
This reverts commit 8c702ce5b4
.
2015-10-21 09:35:17 +02:00
Jürg Lehni
f8595e93c6
Improve some comments.
2015-10-21 02:45:57 +02:00
Jürg Lehni
169f18617c
Address more pending TODOs.
2015-10-21 02:40:12 +02:00
Jürg Lehni
7a95625a13
Remove debug code and TODO from CurveLocation#isCrossing()
2015-10-21 02:36:43 +02:00
Jürg Lehni
8c702ce5b4
No need for special length handling in propagateWinding()
2015-10-21 02:32:56 +02:00
Jürg Lehni
3daa7f78b4
Some comment clean-ups.
2015-10-21 02:24:54 +02:00
Jürg Lehni
341fe1ab4e
Remove all boolean debugging and streamline code.
2015-10-21 02:16:17 +02:00
Jürg Lehni
2cf637d13b
Merge remote-tracking branch 'origin/boolean-fix' into develop
2015-10-21 01:44:15 +02:00
Jürg Lehni
43cf20096a
Implement Curve.getNearestParameter()
2015-10-21 01:43:14 +02:00
Jürg Lehni
8c3d9df06c
Further fine-tune the various EPSILON values based on edge-case tests.
2015-10-21 01:42:26 +02:00
Jürg Lehni
5d6b761d3a
Introduce separate WINDING_EPSILON and improve GEOMETRIC_EPSILON.
...
New values are based on a lot of testing.
2015-10-21 01:16:52 +02:00
Jürg Lehni
eb62530958
Improve CurveLocation#equals().
2015-10-21 01:15:46 +02:00
Jürg Lehni
1f476c2107
Improve CurveLocation#isTouching() to better handle straight lines.
2015-10-21 01:10:24 +02:00
Jürg Lehni
1073340eeb
Do not use GEOMETRIC_EPSILON in Curve.getParameterAt()
...
This caused issues in some rare edge-cases.
2015-10-21 01:09:03 +02:00
Jürg Lehni
d543658c43
Remove old version of Curve#getParameterOf()
2015-10-21 00:17:05 +02:00
Jürg Lehni
140fba56cc
Fix Line#isCollinear() and #isOrthogonal()
2015-10-20 23:37:37 +02:00
Jürg Lehni
bcd6520e66
Merge handling of self-intersection crossings with normal crossings.
...
Shorter code and no additional glitches.
2015-10-20 23:03:40 +02:00
Jürg Lehni
08122131dc
Use isOverlap() instead of _overlap everywhere.
2015-10-20 23:02:50 +02:00
Jürg Lehni
6ccd78e8af
Go back to simpler code to handle visited segments.
...
It appears that the imprecisions addressed in 6cdead0e8c
have since disappeared.
2015-10-20 23:02:19 +02:00
Jürg Lehni
7422e0710f
Some changes to boolean debug logging.
2015-10-20 22:04:30 +02:00
Jürg Lehni
3aa7507ce1
Avoid issues with imprecision in CurveLocation#getCurve() / trySegment()
2015-10-20 22:04:04 +02:00
Jürg Lehni
447feea1da
Improve Curve#getParameterOf() to first check curve points with zero epsilon.
2015-10-20 22:03:45 +02:00
Jürg Lehni
60109e897a
Use 'preserve' to protect #getPoint() against overriding.
2015-10-20 19:22:33 +02:00
Jürg Lehni
3ae0ca6c94
Remove dependency on curve-time comparisons when comparing locations.
...
Locations on consecutive short curves (< 1e-7) where unable to merge due to diff > 1.
Relates to #805
2015-10-20 17:53:40 +02:00
Jürg Lehni
7cea3488c0
Remove dependency on curve-time parameter when figuring out which locations to merge.
2015-10-20 17:17:31 +02:00
Jürg Lehni
5dac7e9d29
Reduce maximum recursion again in addCurveIntersections()
...
32 has lead to many deadlocks.
2015-10-20 16:35:30 +02:00
Jürg Lehni
da43953828
For curves with only one segment, pick the smaller diff between the two locations.
...
Addresses point 1. in https://github.com/paperjs/paper.js/issues/805#issuecomment-147770300
2015-10-20 16:34:40 +02:00
Jürg Lehni
93e9e54ae5
Make sure we cannot find two intersections between two lines.
...
Adresses point 2. in https://github.com/paperjs/paper.js/issues/805#issuecomment-148503018
2015-10-20 15:34:09 +02:00
Jürg Lehni
f2cce4c84d
Rename variable to be less ambiguous.
2015-10-20 15:21:03 +02:00
Jürg Lehni
63303a59f4
Change PathItem#getIntersections() so that the simply circularity checks in addLocations() work.
...
This should address the concerns outlined in https://github.com/paperjs/paper.js/issues/805#issuecomment-147850806
2015-10-20 15:18:09 +02:00
Jürg Lehni
e0c31e4a50
Make static getIntersections() methods 'private'.
2015-10-20 10:02:33 +02:00
Jürg Lehni
f1debf401b
Streamline overlap handling code.
2015-10-20 10:02:00 +02:00
Jürg Lehni
eb2f7e293a
Streamline mouse event handling between View and Item.
...
Consolidating code and making View#onMouseDown/Up/Move/... events work.
2015-10-17 18:13:00 +02:00
sapics
8dfb5191fa
Fix curve evaluate function to finite
2015-10-17 14:38:27 +09:00
Jürg Lehni
3314668a0c
Streamline mouse event handling between View and Item.
...
Consolidating code and making View#onMouseDown/Up/Move/... events work.
2015-10-14 16:25:36 +02:00
Jürg Lehni
9762d2c9e6
Revert "Simplify circular neighbor checks."
...
This reverts commit 2bb3df3314
.
2015-10-13 09:35:13 +02:00
Jürg Lehni
b5c59c881c
Revert "One more simplification."
...
This reverts commit 0ce825f8c9
.
2015-10-13 09:35:08 +02:00
Jürg Lehni
0ce825f8c9
One more simplification.
2015-10-13 08:34:48 +02:00
Jürg Lehni
2bb3df3314
Simplify circular neighbor checks.
...
Relates to #805 .
2015-10-13 08:32:05 +02:00
Jürg Lehni
9de6aa97f2
Third attempt at correctly handling paths as circular lists.
...
Relates to #805 .
2015-10-13 07:59:19 +02:00
Jürg Lehni
f6f6a58fe6
Improve handling of paths as circular lists.
2015-10-13 07:27:25 +02:00
Jürg Lehni
2e552853fd
Handle paths as circular lists in CurveLocation.insert() as well.
...
Relates to #805
2015-10-13 07:23:15 +02:00
Jürg Lehni
0553201de8
Add forgotten semi-colon.
2015-10-13 00:11:24 +02:00
Jürg Lehni
3d33bbdfa3
Clean-up CurveLocation#equals()
2015-10-13 00:10:21 +02:00
Jürg Lehni
f77579079e
Improve CurveTime#equals() to handle locations that wrap around beginnings / ends of paths.
...
See https://github.com/paperjs/paper.js/issues/805#issuecomment-147470240 for details.
2015-10-13 00:06:34 +02:00
iconexperience
f8edf5d8a7
Small refactoring in getConvexHull()
...
Make calculations of distances more concise.
2015-10-12 08:42:36 +02:00
Jürg Lehni
588ddbe011
Add comments to Curve#getParameterOf()
2015-10-11 17:09:04 +02:00
Jürg Lehni
bbc0029252
Go back to simple overlap handling.
...
It appears to produce less glitches.
2015-10-11 17:05:23 +02:00
Jürg Lehni
4500e520ea
Minor code clean-up.
2015-10-11 17:00:23 +02:00
Jürg Lehni
c9f5c02ee4
Decrease GEOMETRIC_EPSILON
...
This appears to be better aligned with the new Curve#getParameterOf() behavior.
2015-10-11 17:00:01 +02:00
Jürg Lehni
c1d0bd21b8
Improve Curve#getParameterOf() to better handle very small curves.
...
See #799
2015-10-11 16:59:03 +02:00
Jürg Lehni
61db3d9d01
Improve handling of boolean debug options.
2015-10-11 16:57:43 +02:00
Jürg Lehni
6cdead0e8c
Add fallback strategy when ending up in a dead-end in tracePaths().
...
This simple fix appears to be able to catch quite a few glitches with very small curves.
2015-10-11 16:56:41 +02:00
Jürg Lehni
247e80f569
Update to latest prepro.js with proper support for strings and scientific numbers.
2015-10-11 15:50:25 +02:00
Jürg Lehni
841381f520
Reactivate new overlap handling.
...
It appears to work better with the new Curve.getParameterOf()
2015-10-11 10:17:03 +02:00
Jürg Lehni
d20cdf5b73
There can only be one self-intersection per curve.
2015-10-11 09:48:55 +02:00
Jürg Lehni
8a122e19d8
Split self-intersection handling into separate method.
...
Increasing readability of both methods.
2015-10-11 09:26:04 +02:00
Jürg Lehni
7aed221801
Some refactoring in static methods of CurveLocation.
2015-10-11 09:18:50 +02:00
Jürg Lehni
99909953a8
Use colors to distinguish faulty boolean paths.
2015-10-09 11:07:43 +02:00
Jürg Lehni
688f580b95
Switch to new Curve.getParameterOf()
...
Simpler code, but improved precision means more glitches to analyze.
2015-10-09 10:34:46 +02:00
Jürg Lehni
48bb0a1be4
Address old TODO in getWinding()
2015-10-09 10:33:43 +02:00
Jürg Lehni
0839dbe1f5
New overlap handling is producing new glitches.
...
Turn it off for now, until further analysis has been done.
2015-10-09 10:27:25 +02:00
Jürg Lehni
b2127a83ad
Revert "Do not start with segments with multiple intersections."
...
This reverts commit 5129fb0050
.
2015-10-09 10:22:54 +02:00
Jürg Lehni
514e6651e6
Revert "Avoid all intersections as starting points for boolean paths."
...
This reverts commit 9590578339
.
2015-10-09 10:19:05 +02:00
Jürg Lehni
c45ae4b51a
Revert "Never starting in intersections allows for further code simplifications."
...
This reverts commit 892154e8f8
.
2015-10-09 10:18:45 +02:00
Jürg Lehni
892154e8f8
Never starting in intersections allows for further code simplifications.
2015-10-09 00:03:34 +02:00
Jürg Lehni
9590578339
Avoid all intersections as starting points for boolean paths.
2015-10-08 23:56:18 +02:00
Jürg Lehni
939a9fe034
Improve overlap handling by actually storing overlap curves on intersections objects.
...
And properly comparing against them in tracePaths().
2015-10-08 23:54:00 +02:00
Jürg Lehni
5129fb0050
Do not start with segments with multiple intersections.
...
Simplifies the required checks at the end, and generally reduces number edge cases.
2015-10-08 23:38:41 +02:00
Jürg Lehni
c9eba83cc7
Improve detection of start segments.
...
Segments with multiple intersections need to be checked thoroughly to avoid errors.
2015-10-08 23:13:37 +02:00
Jürg Lehni
e92a71e8c7
Switch to improved version of Line. getSignedDistance()
...
Based on the error analysis by @iconexperience outlined in #799
2015-10-08 22:56:05 +02:00
Jürg Lehni
5c70f47b6f
Fix colors in reportWindings code.
2015-10-07 23:37:09 +02:00
Jürg Lehni
15d797ac55
Improve linkIntersections() to prevent endless recursions in linked intersections.
2015-10-07 17:20:08 +02:00
Jürg Lehni
3e9d7593cf
Some smaller tweaks in tracePaths()
2015-10-07 10:58:29 +02:00
Jürg Lehni
4fac3ee6fc
Rename getIntersection() -> getBestIntersection()
2015-10-07 10:57:43 +02:00
Jürg Lehni
bfa0459c52
Go back to using Group for divide() results.
...
As they may contain multiple CompoundPaths.
2015-10-07 10:57:09 +02:00
Jürg Lehni
1103c7036f
Remove unnecessary isValid() check on segments without intersections.
...
It was only causing issues without solving anything.
2015-10-07 02:02:27 +02:00
Jürg Lehni
8c56a1a110
Include _visited checks in isValid() calls.
...
This magically reduces the remaining glitches in @iconexperience's test-suite to half.
Relates to #784 .
2015-10-06 22:23:43 +02:00
Jürg Lehni
896b068266
Switch from recursion to a simple loop in getIntersection()
2015-10-06 21:30:51 +02:00
Jürg Lehni
8e4bef217a
Change Curve.getParameterOf() to accept a point instead of x, y arguments.
2015-10-06 21:24:58 +02:00
Jürg Lehni
525e35518d
No need to default to 0 anymore.
...
See 1b343d5347 (commitcomment-13622714)
2015-10-06 21:16:49 +02:00
Jürg Lehni
bc736f439f
Have Numerical.CURVETIME_EPSILON / 10 evaluated at preprocess time.
2015-10-06 21:14:43 +02:00
Jürg Lehni
7f4d8d54f0
Reduce epsilon in addCurveIntersections()
...
1/10 of CURVETIME_EPSILON appears to produce good results. It's probably wise to keep it linked.
2015-10-06 21:14:04 +02:00
Jürg Lehni
3ac3df8d32
Rewrite method for linking and choosing multiple intersections in the same location.
...
The special handling of overlaps reduces the amount of remaining glitches substantially.
Relates to #784 .
2015-10-06 21:09:35 +02:00
Jürg Lehni
adabe9126a
Simplify calculation of tMinNew and tMaxNew.
...
As suggested by @iconexperience in https://github.com/paperjs/paper.js/issues/795#issuecomment-145918347
2015-10-06 20:15:15 +02:00
Jürg Lehni
1b343d5347
Rewrite 04cab797db
to only use one return statement.
2015-10-06 16:31:30 +02:00