mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-22 07:19:57 -05:00
Calculate abscissae directly
This commit is contained in:
parent
0a9a0bdb9b
commit
48e5d3aa8e
1 changed files with 17 additions and 18 deletions
|
@ -196,34 +196,33 @@ function _clipBezierFatLine( v1, v2, v2t ){
|
||||||
if( dmin > maxdist || dmax < mindist ){
|
if( dmin > maxdist || dmax < mindist ){
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
var tmp;
|
||||||
if( dq3 < dq0 ){
|
if( dq3 < dq0 ){
|
||||||
var tmp = dmin;
|
tmp = dmin; dmin = dmax; dmax = tmp;
|
||||||
dmin = dmax;
|
|
||||||
dmax = tmp;
|
|
||||||
}
|
}
|
||||||
// Calculate the convex hull for non-parametric bezier curve D(ti, di(t))
|
// Calculate the convex hull for non-parametric bezier curve D(ti, di(t))
|
||||||
var Dt = _convexhull( dq0, dq1, dq2, dq3 );
|
var Dt = _convexhull( dq0, dq1, dq2, dq3 );
|
||||||
// Now we clip the convex hulls for D(ti, di(t)) with dmin and dmax
|
// Now we clip the convex hulls for D(ti, di(t)) with dmin and dmax
|
||||||
// for the coorresponding t values (tmin, tmax):
|
// for the coorresponding t values (tmin, tmax):
|
||||||
// Portions of curve v2 before tmin and after tmax can safely be clipped away
|
// Portions of curve v2 before tmin and after tmax can safely be clipped away
|
||||||
var tmaxdmin = -Infinity, ixd, ixdx, i, len;
|
var tmaxdmin = -Infinity, ixd, ixdx, i, len, inv_m;
|
||||||
var tmin = Infinity, tmax = -Infinity;
|
var tmin = Infinity, tmax = -Infinity, Dtl, dtlx1, dtly1, dtlx2, dtly2;
|
||||||
// var dmina = [0, dmin, 2, dmin];
|
|
||||||
// var dmaxa = [0, dmax, 2, dmax];
|
|
||||||
for (i = 0, len = Dt.length; i < len; i++) {
|
for (i = 0, len = Dt.length; i < len; i++) {
|
||||||
var Dtl = Dt[i];
|
Dtl = Dt[i];
|
||||||
// ixd = _intersectLines( Dtl, dmina);
|
dtlx1 = Dtl[0]; dtly1 = Dtl[1]; dtlx2 = Dtl[2]; dtly2 = Dtl[3];
|
||||||
// TODO: Optimize: Avaoid creating point objects in Line.intersect?! - speeds up by 30%!
|
if( dtly2 < dtly1 ){
|
||||||
ixd = Line.intersectRaw( Dtl[0], Dtl[1], Dtl[2], Dtl[3], 0, dmin, 2, dmin, false);
|
tmp = dtly2; dtly2 = dtly1; dtly1 = tmp;
|
||||||
if( ixd ){
|
tmp = dtlx2; dtlx2 = dtlx1; dtlx1 = tmp;
|
||||||
ixdx = ixd[0];
|
}
|
||||||
|
// we know that (dtlx2 - dtlx1) is never 0
|
||||||
|
inv_m = (dtly2 - dtly1) / (dtlx2 - dtlx1);
|
||||||
|
if( dmin >= dtly1 && dmin <= dtly2 ){
|
||||||
|
ixdx = dtlx1 + (dmin - dtly1) / inv_m;
|
||||||
if ( ixdx < tmin ) tmin = ixdx;
|
if ( ixdx < tmin ) tmin = ixdx;
|
||||||
if ( ixdx > tmaxdmin ) tmaxdmin = ixdx;
|
if ( ixdx > tmaxdmin ) tmaxdmin = ixdx;
|
||||||
}
|
}
|
||||||
// ixd = _intersectLines( Dtl, dmaxa);
|
if( dmax >= dtly1 && dmax <= dtly2 ){
|
||||||
ixd = Line.intersectRaw( Dtl[0], Dtl[1], Dtl[2], Dtl[3], 0, dmax, 2, dmax, false);
|
ixdx = dtlx1 + (dmax - dtly1) / inv_m;
|
||||||
if( ixd ){
|
|
||||||
ixdx = ixd[0];
|
|
||||||
if( ixdx > tmax ) tmax = ixdx;
|
if( ixdx > tmax ) tmax = ixdx;
|
||||||
if( ixdx < tmin ) tmin = 0;
|
if( ixdx < tmin ) tmin = 0;
|
||||||
}
|
}
|
||||||
|
@ -233,7 +232,7 @@ function _clipBezierFatLine( v1, v2, v2t ){
|
||||||
if(tmin === Infinity || tmax === -Infinity){
|
if(tmin === Infinity || tmax === -Infinity){
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if( tmaxdmin > tmax ) tmax = 1;
|
if( tmaxdmin > tmax ){ tmax = 1; }
|
||||||
// Debug: Plot the non-parametric graph and hull
|
// Debug: Plot the non-parametric graph and hull
|
||||||
// plotD_vs_t( 500, 110, Dt, [dq0, dq1, dq2, dq3], v1, dmin, dmax, tmin, tmax, 1.0 / ( tmax - tmin + 0.3 ) )
|
// plotD_vs_t( 500, 110, Dt, [dq0, dq1, dq2, dq3], v1, dmin, dmax, tmin, tmax, 1.0 / ( tmax - tmin + 0.3 ) )
|
||||||
// tmin and tmax are within the range (0, 1). We need to project it to the original
|
// tmin and tmax are within the range (0, 1). We need to project it to the original
|
||||||
|
|
Loading…
Reference in a new issue