mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
Use same naming for prev* variables as elsewhere in boolean code.
This commit is contained in:
parent
46ea9da423
commit
cad2858070
1 changed files with 32 additions and 31 deletions
|
@ -300,22 +300,22 @@ PathItem.inject(new function() {
|
||||||
* The curve does not have to be a monotone curve.
|
* The curve does not have to be a monotone curve.
|
||||||
*
|
*
|
||||||
* @param v the values of the curve
|
* @param v the values of the curve
|
||||||
* @param vPrev the values of the previous curve
|
* @param prevV the values of the previous curve
|
||||||
* @param px x coordinate of the point to be examined
|
* @param px x coordinate of the point to be examined
|
||||||
* @param py y coordinate of the point to be examined
|
* @param py y coordinate of the point to be examined
|
||||||
* @param windings an array of length 2. Index 0 is the windings to the
|
* @param windings an array of length 2, windings[0] contains the winding
|
||||||
* left, index 1 to the right.
|
* number to the left, windings[1] to the right
|
||||||
* @param isOnCurve
|
* @param isOnCurve
|
||||||
* @param coord The coordinate direction of the cast ray (0 = x, 1 = y)
|
* @param coord the coordinate direction of the cast ray (0 = x, 1 = y)
|
||||||
*/
|
*/
|
||||||
function addWinding(v, vPrev, px, py, windings, isOnCurve, coord) {
|
function addWinding(v, prevV, px, py, windings, isOnCurve, coord) {
|
||||||
var epsilon = /*#=*/Numerical.WINDING_EPSILON,
|
var epsilon = /*#=*/Numerical.WINDING_EPSILON,
|
||||||
pa = coord ? py : px, // point's abscissa
|
pa = coord ? py : px, // point's abscissa
|
||||||
po = coord ? px : py, // point's ordinate
|
po = coord ? px : py, // point's ordinate
|
||||||
vo0 = v[1 - coord],
|
vo0 = v[1 - coord],
|
||||||
vo3 = v[7 - coord];
|
vo3 = v[7 - coord];
|
||||||
if ((vo0 > po && vo3 > po) ||
|
if (vo0 > po && vo3 > po ||
|
||||||
(vo0 < po && vo3 < po)) {
|
vo0 < po && vo3 < po) {
|
||||||
// If curve is outside the ordinates' range, no intersection with
|
// If curve is outside the ordinates' range, no intersection with
|
||||||
// the ray is possible.
|
// the ray is possible.
|
||||||
return v;
|
return v;
|
||||||
|
@ -332,12 +332,13 @@ PathItem.inject(new function() {
|
||||||
// +-----+
|
// +-----+
|
||||||
// ----+ |
|
// ----+ |
|
||||||
// +-----+
|
// +-----+
|
||||||
if ( va1 <= aAfter && va3 >= aBefore ||
|
if (va1 <= aAfter && va3 >= aBefore ||
|
||||||
va3 <= aAfter && va1 >= aBefore)
|
va3 <= aAfter && va1 >= aBefore) {
|
||||||
isOnCurve[0] = true;
|
isOnCurve[0] = true;
|
||||||
|
}
|
||||||
// If curve does not change in ordinate direction, windings will be
|
// If curve does not change in ordinate direction, windings will be
|
||||||
// added by adjacent curves.
|
// added by adjacent curves.
|
||||||
return vPrev;
|
return prevV;
|
||||||
}
|
}
|
||||||
var roots = [],
|
var roots = [],
|
||||||
a = po === vo0 ? va0
|
a = po === vo0 ? va0
|
||||||
|
@ -347,12 +348,12 @@ PathItem.inject(new function() {
|
||||||
( va0 > aAfter && va1 > aAfter &&
|
( va0 > aAfter && va1 > aAfter &&
|
||||||
va2 > aAfter && va3 > aAfter)
|
va2 > aAfter && va3 > aAfter)
|
||||||
? (va0 + va3) / 2
|
? (va0 + va3) / 2
|
||||||
: Curve.solveCubic(v, coord ? 0 : 1, po, roots, 0, 1) === 1
|
: Curve.solveCubic(v, coord ? 0 : 1, po, roots, 0, 1) === 1
|
||||||
? Curve.getPoint(v, roots[0])[coord ? 'y' : 'x']
|
? Curve.getPoint(v, roots[0])[coord ? 'y' : 'x']
|
||||||
: (va0 + va3) / 2;
|
: (va0 + va3) / 2;
|
||||||
var winding = vo0 > vo3 ? 1 : -1,
|
var winding = vo0 > vo3 ? 1 : -1,
|
||||||
prevWinding = vPrev[1 - coord] > vPrev[7 - coord] ? 1 : -1,
|
prevWinding = prevV[1 - coord] > prevV[7 - coord] ? 1 : -1,
|
||||||
prevAEnd = vPrev[6 + coord];
|
prevAEnd = prevV[6 + coord];
|
||||||
if (po !== vo0) {
|
if (po !== vo0) {
|
||||||
// Standard case, curve is crossed by not at it's start point
|
// Standard case, curve is crossed by not at it's start point
|
||||||
if (a < aBefore) {
|
if (a < aBefore) {
|
||||||
|
@ -373,8 +374,8 @@ PathItem.inject(new function() {
|
||||||
if (prevAEnd >= aBefore) {
|
if (prevAEnd >= aBefore) {
|
||||||
windings[1] += winding;
|
windings[1] += winding;
|
||||||
}
|
}
|
||||||
} else if ((prevAEnd < aBefore && a >= aBefore)
|
} else if (prevAEnd < aBefore && a >= aBefore
|
||||||
|| (prevAEnd > aAfter && a <= aAfter)) {
|
|| prevAEnd > aAfter && a <= aAfter) {
|
||||||
// Point is on a horizontal curve between previous non-horizontal
|
// Point is on a horizontal curve between previous non-horizontal
|
||||||
// and current curve
|
// and current curve
|
||||||
isOnCurve[0] = true;
|
isOnCurve[0] = true;
|
||||||
|
@ -396,7 +397,7 @@ PathItem.inject(new function() {
|
||||||
pathWindings = [0, 0],
|
pathWindings = [0, 0],
|
||||||
onPathWinding = 0,
|
onPathWinding = 0,
|
||||||
isOnPath = [false],
|
isOnPath = [false],
|
||||||
vPrev,
|
prevV,
|
||||||
coord = horizontal ? 1 : 0,
|
coord = horizontal ? 1 : 0,
|
||||||
po = horizontal ? point.x : point.y,
|
po = horizontal ? point.x : point.y,
|
||||||
pa = horizontal ? point.y : point.x,
|
pa = horizontal ? point.y : point.x,
|
||||||
|
@ -407,20 +408,21 @@ PathItem.inject(new function() {
|
||||||
var path = curve.getPath();
|
var path = curve.getPath();
|
||||||
if (i === 0 || curves[i - 1].getPath() !== path) {
|
if (i === 0 || curves[i - 1].getPath() !== path) {
|
||||||
// On new path, determine values of last non-horizontal curve.
|
// On new path, determine values of last non-horizontal curve.
|
||||||
vPrev = null;
|
prevV = null;
|
||||||
var curvePrev = curve.getPrevious();
|
var curvePrev = curve.getPrevious();
|
||||||
while (!vPrev && curvePrev && curvePrev != curve) {
|
while (!prevV && curvePrev && curvePrev != curve) {
|
||||||
var v2 = curvePrev.getValues();
|
var v2 = curvePrev.getValues();
|
||||||
if (v2[1 - coord] != v2[7 - coord]) {
|
if (v2[1 - coord] != v2[7 - coord]) {
|
||||||
vPrev = v2;
|
prevV = v2;
|
||||||
}
|
}
|
||||||
curvePrev = curvePrev.getPrevious();
|
curvePrev = curvePrev.getPrevious();
|
||||||
}
|
}
|
||||||
if (!vPrev) {
|
if (!prevV) {
|
||||||
vPrev = curve.getValues();
|
prevV = curve.getValues();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
var v = curve.getValues(),
|
var v = curve.getValues(),
|
||||||
|
// Get the other coordinate values (x -> y, y -> x):
|
||||||
vo0 = v[1 - coord],
|
vo0 = v[1 - coord],
|
||||||
vo1 = v[3 - coord],
|
vo1 = v[3 - coord],
|
||||||
vo2 = v[5 - coord],
|
vo2 = v[5 - coord],
|
||||||
|
@ -438,10 +440,9 @@ PathItem.inject(new function() {
|
||||||
va2 < aBefore && va3 < aBefore) ||
|
va2 < aBefore && va3 < aBefore) ||
|
||||||
( va0 > aAfter && va1 > aAfter &&
|
( va0 > aAfter && va1 > aAfter &&
|
||||||
va2 > aAfter && va3 > aAfter)
|
va2 > aAfter && va3 > aAfter)
|
||||||
? [v]
|
? [v] : Curve.getMonoCurves(v, coord);
|
||||||
: Curve.getMonoCurves(v, coord);
|
|
||||||
for (var j = 0; j < monoCurves.length; j++) {
|
for (var j = 0; j < monoCurves.length; j++) {
|
||||||
vPrev = addWinding(monoCurves[j], vPrev, point.x, point.y,
|
prevV = addWinding(monoCurves[j], prevV, point.x, point.y,
|
||||||
pathWindings, isOnPath, coord);
|
pathWindings, isOnPath, coord);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -987,7 +988,7 @@ Path.inject(/** @lends Path# */{
|
||||||
intercepts = [],
|
intercepts = [],
|
||||||
monoCurves = [],
|
monoCurves = [],
|
||||||
roots = [],
|
roots = [],
|
||||||
windingPrev = 0;
|
prevWinding = 0;
|
||||||
// Get values for all y-monotone curves that intersect the ray at y.
|
// Get values for all y-monotone curves that intersect the ray at y.
|
||||||
for (var i = 0, l = curves.length; i < l; i++) {
|
for (var i = 0, l = curves.length; i < l; i++) {
|
||||||
var v = curves[i].getValues();
|
var v = curves[i].getValues();
|
||||||
|
@ -999,8 +1000,8 @@ Path.inject(/** @lends Path# */{
|
||||||
if (y >= v[1] && y <= v[7] || y >= v[7] && y <= v[1]) {
|
if (y >= v[1] && y <= v[7] || y >= v[7] && y <= v[1]) {
|
||||||
var winding = v[1] > v[7] ? 1 : v[1] < v[7] ? -1 : 0;
|
var winding = v[1] > v[7] ? 1 : v[1] < v[7] ? -1 : 0;
|
||||||
if (winding) {
|
if (winding) {
|
||||||
monoCurves.push({values: v, winding: winding});
|
monoCurves.push({ values: v, winding: winding });
|
||||||
windingPrev = winding;
|
prevWinding = winding;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1017,9 +1018,9 @@ Path.inject(/** @lends Path# */{
|
||||||
: Curve.solveCubic(v, 1, y, roots, 0, 1) === 1
|
: Curve.solveCubic(v, 1, y, roots, 0, 1) === 1
|
||||||
? Curve.getPoint(v, roots[0]).x
|
? Curve.getPoint(v, roots[0]).x
|
||||||
: (v[0] + v[6]) / 2;
|
: (v[0] + v[6]) / 2;
|
||||||
// if (y != v[1] || winding != windingPrev)
|
// if (y != v[1] || winding != prevWinding)
|
||||||
intercepts.push(x);
|
intercepts.push(x);
|
||||||
windingPrev = winding;
|
prevWinding = winding;
|
||||||
}
|
}
|
||||||
intercepts.sort(function(a, b) {
|
intercepts.sort(function(a, b) {
|
||||||
return a - b;
|
return a - b;
|
||||||
|
|
Loading…
Reference in a new issue