Clean up Path#curveTo() code.

This commit is contained in:
Jürg Lehni 2011-04-28 13:12:21 +01:00
parent 7dce6f3a6c
commit 0d697403b5

View file

@ -646,9 +646,9 @@ var Path = this.Path = PathItem.extend({
// and the cubic is A B C D, // and the cubic is A B C D,
// B = E + 1/3 (A - E) // B = E + 1/3 (A - E)
// C = E + 1/3 (D - E) // C = E + 1/3 (D - E)
var current = getCurrentSegment(this); var current = getCurrentSegment(this)._point;
this.cubicCurveTo( this.cubicCurveTo(
handle.add(current._point.subtract(handle).multiply(1/3)), handle.add(current.subtract(handle).multiply(1/3)),
handle.add(to.subtract(handle).multiply(1/3)), handle.add(to.subtract(handle).multiply(1/3)),
to to
); );
@ -657,15 +657,13 @@ var Path = this.Path = PathItem.extend({
curveTo: function(through, to, parameter) { curveTo: function(through, to, parameter) {
through = Point.read(arguments, 0, 1); through = Point.read(arguments, 0, 1);
to = Point.read(arguments, 1, 1); to = Point.read(arguments, 1, 1);
var t = parameter; var t = Base.pick(parameter, 0.5),
if (t == null) t1 = 1 - t,
t = 0.5; current = getCurrentSegment(this)._point,
var current = getCurrentSegment(this)._point;
// handle = (through - (1 - t)^2 * current - t^2 * to) / // handle = (through - (1 - t)^2 * current - t^2 * to) /
// (2 * (1 - t) * t) // (2 * (1 - t) * t)
var t1 = 1 - t, handle = through.subtract(current.multiply(t1 * t1))
handle = through.subtract(current.multiply(t1 * t1)).subtract( .subtract(to.multiply(t * t)).divide(2 * t * t1);
to.multiply(t * t)).divide(2 * t * t1);
if (handle.isNaN()) if (handle.isNaN())
throw new Error( throw new Error(
"Cannot put a curve through points with parameter=" + t); "Cannot put a curve through points with parameter=" + t);
@ -673,9 +671,9 @@ var Path = this.Path = PathItem.extend({
}, },
arcTo: function(to, clockwise) { arcTo: function(to, clockwise) {
var through, to;
// Get the start point: // Get the start point:
var current = getCurrentSegment(this); var current = getCurrentSegment(this),
through;
if (arguments[1] && typeof arguments[1] != 'boolean') { if (arguments[1] && typeof arguments[1] != 'boolean') {
through = Point.read(arguments, 0, 1); through = Point.read(arguments, 0, 1);
to = Point.read(arguments, 1, 1); to = Point.read(arguments, 1, 1);